@decidables/discountable-elements 0.4.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -10,20 +10,20 @@
10
10
  * SPDX-License-Identifier: BSD-3-Clause
11
11
  */
12
12
  const t$2 = globalThis,
13
- e$3 = t$2.ShadowRoot && (undefined === t$2.ShadyCSS || t$2.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
14
- s$3 = Symbol(),
15
- o$5 = new WeakMap();
13
+ e$3 = t$2.ShadowRoot && (void 0 === t$2.ShadyCSS || t$2.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
14
+ s$4 = Symbol(),
15
+ o$6 = new WeakMap();
16
16
  let n$4 = class n {
17
17
  constructor(t, e, o) {
18
- if (this._$cssResult$ = true, o !== s$3) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
18
+ if (this._$cssResult$ = true, o !== s$4) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
19
19
  this.cssText = t, this.t = e;
20
20
  }
21
21
  get styleSheet() {
22
22
  let t = this.o;
23
23
  const s = this.t;
24
- if (e$3 && undefined === t) {
25
- const e = undefined !== s && 1 === s.length;
26
- e && (t = o$5.get(s)), undefined === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$5.set(s, t));
24
+ if (e$3 && void 0 === t) {
25
+ const e = void 0 !== s && 1 === s.length;
26
+ e && (t = o$6.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$6.set(s, t));
27
27
  }
28
28
  return t;
29
29
  }
@@ -31,26 +31,26 @@
31
31
  return this.cssText;
32
32
  }
33
33
  };
34
- const r$5 = t => new n$4("string" == typeof t ? t : t + "", undefined, s$3),
34
+ const r$4 = t => new n$4("string" == typeof t ? t : t + "", void 0, s$4),
35
35
  i$5 = (t, ...e) => {
36
36
  const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
37
37
  if (true === t._$cssResult$) return t.cssText;
38
38
  if ("number" == typeof t) return t;
39
39
  throw Error("Value passed to 'css' function must be a 'css' function result: " + t + ". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.");
40
40
  })(s) + t[o + 1], t[0]);
41
- return new n$4(o, t, s$3);
41
+ return new n$4(o, t, s$4);
42
42
  },
43
43
  S$1 = (s, o) => {
44
44
  if (e$3) s.adoptedStyleSheets = o.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet);else for (const e of o) {
45
45
  const o = document.createElement("style"),
46
46
  n = t$2.litNonce;
47
- undefined !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
47
+ void 0 !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
48
48
  }
49
49
  },
50
50
  c$6 = e$3 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
51
51
  let e = "";
52
52
  for (const s of t.cssRules) e += s.cssText;
53
- return r$5(e);
53
+ return r$4(e);
54
54
  })(t) : t;
55
55
 
56
56
  /**
@@ -61,9 +61,9 @@
61
61
  const {
62
62
  is: i$4,
63
63
  defineProperty: e$2,
64
- getOwnPropertyDescriptor: r$4,
65
- getOwnPropertyNames: h$2,
66
- getOwnPropertySymbols: o$4,
64
+ getOwnPropertyDescriptor: h$2,
65
+ getOwnPropertyNames: r$3,
66
+ getOwnPropertySymbols: o$5,
67
67
  getPrototypeOf: n$3
68
68
  } = Object,
69
69
  a$3 = globalThis,
@@ -104,33 +104,34 @@
104
104
  }
105
105
  },
106
106
  f$3 = (t, s) => !i$4(t, s),
107
- y$2 = {
107
+ b$2 = {
108
108
  attribute: true,
109
109
  type: String,
110
110
  converter: u$1,
111
111
  reflect: false,
112
+ useDefault: false,
112
113
  hasChanged: f$3
113
114
  };
114
115
  Symbol.metadata ??= Symbol("metadata"), a$3.litPropertyMetadata ??= new WeakMap();
115
- let b$2 = class b extends HTMLElement {
116
+ let y$2 = class y extends HTMLElement {
116
117
  static addInitializer(t) {
117
118
  this._$Ei(), (this.l ??= []).push(t);
118
119
  }
119
120
  static get observedAttributes() {
120
121
  return this.finalize(), this._$Eh && [...this._$Eh.keys()];
121
122
  }
122
- static createProperty(t, s = y$2) {
123
- if (s.state && (s.attribute = false), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
123
+ static createProperty(t, s = b$2) {
124
+ if (s.state && (s.attribute = false), this._$Ei(), this.prototype.hasOwnProperty(t) && ((s = Object.create(s)).wrapped = true), this.elementProperties.set(t, s), !s.noAccessor) {
124
125
  const i = Symbol(),
125
- r = this.getPropertyDescriptor(t, i, s);
126
- undefined !== r && e$2(this.prototype, t, r);
126
+ h = this.getPropertyDescriptor(t, i, s);
127
+ void 0 !== h && e$2(this.prototype, t, h);
127
128
  }
128
129
  }
129
130
  static getPropertyDescriptor(t, s, i) {
130
131
  const {
131
132
  get: e,
132
- set: h
133
- } = r$4(this.prototype, t) ?? {
133
+ set: r
134
+ } = h$2(this.prototype, t) ?? {
134
135
  get() {
135
136
  return this[s];
136
137
  },
@@ -139,41 +140,39 @@
139
140
  }
140
141
  };
141
142
  return {
142
- get() {
143
- return e?.call(this);
144
- },
143
+ get: e,
145
144
  set(s) {
146
- const r = e?.call(this);
147
- h.call(this, s), this.requestUpdate(t, r, i);
145
+ const h = e?.call(this);
146
+ r?.call(this, s), this.requestUpdate(t, h, i);
148
147
  },
149
148
  configurable: true,
150
149
  enumerable: true
151
150
  };
152
151
  }
153
152
  static getPropertyOptions(t) {
154
- return this.elementProperties.get(t) ?? y$2;
153
+ return this.elementProperties.get(t) ?? b$2;
155
154
  }
156
155
  static _$Ei() {
157
156
  if (this.hasOwnProperty(d$1("elementProperties"))) return;
158
157
  const t = n$3(this);
159
- t.finalize(), undefined !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
158
+ t.finalize(), void 0 !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
160
159
  }
161
160
  static finalize() {
162
161
  if (this.hasOwnProperty(d$1("finalized"))) return;
163
162
  if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
164
163
  const t = this.properties,
165
- s = [...h$2(t), ...o$4(t)];
164
+ s = [...r$3(t), ...o$5(t)];
166
165
  for (const i of s) this.createProperty(i, t[i]);
167
166
  }
168
167
  const t = this[Symbol.metadata];
169
168
  if (null !== t) {
170
169
  const s = litPropertyMetadata.get(t);
171
- if (undefined !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
170
+ if (void 0 !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
172
171
  }
173
172
  this._$Eh = new Map();
174
173
  for (const [t, s] of this.elementProperties) {
175
174
  const i = this._$Eu(t, s);
176
- undefined !== i && this._$Eh.set(i, t);
175
+ void 0 !== i && this._$Eh.set(i, t);
177
176
  }
178
177
  this.elementStyles = this.finalizeStyles(this.styles);
179
178
  }
@@ -182,21 +181,21 @@
182
181
  if (Array.isArray(s)) {
183
182
  const e = new Set(s.flat(1 / 0).reverse());
184
183
  for (const s of e) i.unshift(c$6(s));
185
- } else undefined !== s && i.push(c$6(s));
184
+ } else void 0 !== s && i.push(c$6(s));
186
185
  return i;
187
186
  }
188
187
  static _$Eu(t, s) {
189
188
  const i = s.attribute;
190
- return false === i ? undefined : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : undefined;
189
+ return false === i ? void 0 : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : void 0;
191
190
  }
192
191
  constructor() {
193
- super(), this._$Ep = undefined, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
192
+ super(), this._$Ep = void 0, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
194
193
  }
195
194
  _$Ev() {
196
195
  this._$ES = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
197
196
  }
198
197
  addController(t) {
199
- (this._$EO ??= new Set()).add(t), undefined !== this.renderRoot && this.isConnected && t.hostConnected?.();
198
+ (this._$EO ??= new Set()).add(t), void 0 !== this.renderRoot && this.isConnected && t.hostConnected?.();
200
199
  }
201
200
  removeController(t) {
202
201
  this._$EO?.delete(t);
@@ -221,36 +220,44 @@
221
220
  attributeChangedCallback(t, s, i) {
222
221
  this._$AK(t, i);
223
222
  }
224
- _$EC(t, s) {
223
+ _$ET(t, s) {
225
224
  const i = this.constructor.elementProperties.get(t),
226
225
  e = this.constructor._$Eu(t, i);
227
- if (undefined !== e && true === i.reflect) {
228
- const r = (undefined !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
229
- this._$Em = t, null == r ? this.removeAttribute(e) : this.setAttribute(e, r), this._$Em = null;
226
+ if (void 0 !== e && true === i.reflect) {
227
+ const h = (void 0 !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
228
+ this._$Em = t, null == h ? this.removeAttribute(e) : this.setAttribute(e, h), this._$Em = null;
230
229
  }
231
230
  }
232
231
  _$AK(t, s) {
233
232
  const i = this.constructor,
234
233
  e = i._$Eh.get(t);
235
- if (undefined !== e && this._$Em !== e) {
234
+ if (void 0 !== e && this._$Em !== e) {
236
235
  const t = i.getPropertyOptions(e),
237
- r = "function" == typeof t.converter ? {
236
+ h = "function" == typeof t.converter ? {
238
237
  fromAttribute: t.converter
239
- } : undefined !== t.converter?.fromAttribute ? t.converter : u$1;
240
- this._$Em = e, this[e] = r.fromAttribute(s, t.type), this._$Em = null;
238
+ } : void 0 !== t.converter?.fromAttribute ? t.converter : u$1;
239
+ this._$Em = e;
240
+ const r = h.fromAttribute(s, t.type);
241
+ this[e] = r ?? this._$Ej?.get(e) ?? r, this._$Em = null;
241
242
  }
242
243
  }
243
244
  requestUpdate(t, s, i) {
244
- if (undefined !== t) {
245
- if (i ??= this.constructor.getPropertyOptions(t), !(i.hasChanged ?? f$3)(this[t], s)) return;
246
- this.P(t, s, i);
247
- }
248
- false === this.isUpdatePending && (this._$ES = this._$ET());
249
- }
250
- P(t, s, i) {
251
- this._$AL.has(t) || this._$AL.set(t, s), true === i.reflect && this._$Em !== t && (this._$Ej ??= new Set()).add(t);
252
- }
253
- async _$ET() {
245
+ if (void 0 !== t) {
246
+ const e = this.constructor,
247
+ h = this[t];
248
+ if (i ??= e.getPropertyOptions(t), !((i.hasChanged ?? f$3)(h, s) || i.useDefault && i.reflect && h === this._$Ej?.get(t) && !this.hasAttribute(e._$Eu(t, i)))) return;
249
+ this.C(t, s, i);
250
+ }
251
+ false === this.isUpdatePending && (this._$ES = this._$EP());
252
+ }
253
+ C(t, s, {
254
+ useDefault: i,
255
+ reflect: e,
256
+ wrapped: h
257
+ }, r) {
258
+ i && !(this._$Ej ??= new Map()).has(t) && (this._$Ej.set(t, r ?? s ?? this[t]), true !== h || void 0 !== r) || (this._$AL.has(t) || (this.hasUpdated || i || (s = void 0), this._$AL.set(t, s)), true === e && this._$Em !== t && (this._$Eq ??= new Set()).add(t));
259
+ }
260
+ async _$EP() {
254
261
  this.isUpdatePending = true;
255
262
  try {
256
263
  await this._$ES;
@@ -268,17 +275,23 @@
268
275
  if (!this.hasUpdated) {
269
276
  if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
270
277
  for (const [t, s] of this._$Ep) this[t] = s;
271
- this._$Ep = undefined;
278
+ this._$Ep = void 0;
272
279
  }
273
280
  const t = this.constructor.elementProperties;
274
- if (t.size > 0) for (const [s, i] of t) true !== i.wrapped || this._$AL.has(s) || undefined === this[s] || this.P(s, this[s], i);
281
+ if (t.size > 0) for (const [s, i] of t) {
282
+ const {
283
+ wrapped: t
284
+ } = i,
285
+ e = this[s];
286
+ true !== t || this._$AL.has(s) || void 0 === e || this.C(s, void 0, i, e);
287
+ }
275
288
  }
276
289
  let t = false;
277
290
  const s = this._$AL;
278
291
  try {
279
- t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EU();
292
+ t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EM();
280
293
  } catch (s) {
281
- throw t = false, this._$EU(), s;
294
+ throw t = false, this._$EM(), s;
282
295
  }
283
296
  t && this._$AE(s);
284
297
  }
@@ -286,7 +299,7 @@
286
299
  _$AE(t) {
287
300
  this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t)), this.updated(t);
288
301
  }
289
- _$EU() {
302
+ _$EM() {
290
303
  this._$AL = new Map(), this.isUpdatePending = false;
291
304
  }
292
305
  get updateComplete() {
@@ -299,16 +312,16 @@
299
312
  return true;
300
313
  }
301
314
  update(t) {
302
- this._$Ej &&= this._$Ej.forEach(t => this._$EC(t, this[t])), this._$EU();
315
+ this._$Eq &&= this._$Eq.forEach(t => this._$ET(t, this[t])), this._$EM();
303
316
  }
304
317
  updated(t) {}
305
318
  firstUpdated(t) {}
306
319
  };
307
- b$2.elementStyles = [], b$2.shadowRootOptions = {
320
+ y$2.elementStyles = [], y$2.shadowRootOptions = {
308
321
  mode: "open"
309
- }, b$2[d$1("elementProperties")] = new Map(), b$2[d$1("finalized")] = new Map(), p$1?.({
310
- ReactiveElement: b$2
311
- }), (a$3.reactiveElementVersions ??= []).push("2.0.4");
322
+ }, y$2[d$1("elementProperties")] = new Map(), y$2[d$1("finalized")] = new Map(), p$1?.({
323
+ ReactiveElement: y$2
324
+ }), (a$3.reactiveElementVersions ??= []).push("2.1.1");
312
325
 
313
326
  /**
314
327
  * @license
@@ -317,15 +330,15 @@
317
330
  */
318
331
  const t$1 = globalThis,
319
332
  i$3 = t$1.trustedTypes,
320
- s$2 = i$3 ? i$3.createPolicy("lit-html", {
333
+ s$3 = i$3 ? i$3.createPolicy("lit-html", {
321
334
  createHTML: t => t
322
- }) : undefined,
335
+ }) : void 0,
323
336
  e$1 = "$lit$",
324
337
  h$1 = `lit$${Math.random().toFixed(9).slice(2)}$`,
325
- o$3 = "?" + h$1,
326
- n$2 = `<${o$3}>`,
327
- r$3 = document,
328
- l = () => r$3.createComment(""),
338
+ o$4 = "?" + h$1,
339
+ n$2 = `<${o$4}>`,
340
+ r$2 = document,
341
+ l = () => r$2.createComment(""),
329
342
  c$4 = t => null === t || "object" != typeof t && "function" != typeof t,
330
343
  a$2 = Array.isArray,
331
344
  u = t => a$2(t) || "function" == typeof t?.[Symbol.iterator],
@@ -347,10 +360,10 @@
347
360
  T = Symbol.for("lit-noChange"),
348
361
  E$1 = Symbol.for("lit-nothing"),
349
362
  A$2 = new WeakMap(),
350
- C$1 = r$3.createTreeWalker(r$3, 129);
363
+ C$1 = r$2.createTreeWalker(r$2, 129);
351
364
  function P(t, i) {
352
365
  if (!a$2(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
353
- return undefined !== s$2 ? s$2.createHTML(i) : i;
366
+ return void 0 !== s$3 ? s$3.createHTML(i) : i;
354
367
  }
355
368
  const V = (t, i) => {
356
369
  const s = t.length - 1,
@@ -364,7 +377,7 @@
364
377
  u,
365
378
  d = -1,
366
379
  y = 0;
367
- for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f$2 ? "!--" === u[1] ? c = v$1 : undefined !== u[1] ? c = _ : undefined !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : undefined !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f$2, d = -1) : undefined === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = undefined === u[3] ? m : '"' === u[3] ? g$1 : p) : c === g$1 || c === p ? c = m : c === v$1 || c === _ ? c = f$2 : (c = m, r = undefined);
380
+ for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f$2 ? "!--" === u[1] ? c = v$1 : void 0 !== u[1] ? c = _ : void 0 !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : void 0 !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f$2, d = -1) : void 0 === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = void 0 === u[3] ? m : '"' === u[3] ? g$1 : p) : c === g$1 || c === p ? c = m : c === v$1 || c === _ ? c = f$2 : (c = m, r = void 0);
368
381
  const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
369
382
  l += c === f$2 ? s + n$2 : d >= 0 ? (o.push(a), s.slice(0, d) + e$1 + s.slice(d) + h$1 + x) : s + h$1 + (-2 === d ? i : x);
370
383
  }
@@ -415,7 +428,7 @@
415
428
  r.append(t[s], l());
416
429
  }
417
430
  }
418
- } else if (8 === r.nodeType) if (r.data === o$3) d.push({
431
+ } else if (8 === r.nodeType) if (r.data === o$4) d.push({
419
432
  type: 2,
420
433
  index: c
421
434
  });else {
@@ -429,19 +442,19 @@
429
442
  }
430
443
  }
431
444
  static createElement(t, i) {
432
- const s = r$3.createElement("template");
445
+ const s = r$2.createElement("template");
433
446
  return s.innerHTML = t, s;
434
447
  }
435
448
  };
436
449
  function S(t, i, s = t, e) {
437
450
  if (i === T) return i;
438
- let h = undefined !== e ? s._$Co?.[e] : s._$Cl;
439
- const o = c$4(i) ? undefined : i._$litDirective$;
440
- return h?.constructor !== o && (h?._$AO?.(false), undefined === o ? h = undefined : (h = new o(t), h._$AT(t, s, e)), undefined !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), undefined !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
451
+ let h = void 0 !== e ? s._$Co?.[e] : s._$Cl;
452
+ const o = c$4(i) ? void 0 : i._$litDirective$;
453
+ return h?.constructor !== o && (h?._$AO?.(false), void 0 === o ? h = void 0 : (h = new o(t), h._$AT(t, s, e)), void 0 !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), void 0 !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
441
454
  }
442
455
  let M$1 = class M {
443
456
  constructor(t, i) {
444
- this._$AV = [], this._$AN = undefined, this._$AD = t, this._$AM = i;
457
+ this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = i;
445
458
  }
446
459
  get parentNode() {
447
460
  return this._$AM.parentNode;
@@ -456,24 +469,24 @@
456
469
  },
457
470
  parts: s
458
471
  } = this._$AD,
459
- e = (t?.creationScope ?? r$3).importNode(i, true);
472
+ e = (t?.creationScope ?? r$2).importNode(i, true);
460
473
  C$1.currentNode = e;
461
474
  let h = C$1.nextNode(),
462
475
  o = 0,
463
476
  n = 0,
464
477
  l = s[0];
465
- for (; undefined !== l;) {
478
+ for (; void 0 !== l;) {
466
479
  if (o === l.index) {
467
480
  let i;
468
481
  2 === l.type ? i = new R(h, h.nextSibling, this, t) : 1 === l.type ? i = new l.ctor(h, l.name, l.strings, this, t) : 6 === l.type && (i = new z(h, this, t)), this._$AV.push(i), l = s[++n];
469
482
  }
470
483
  o !== l?.index && (h = C$1.nextNode(), o++);
471
484
  }
472
- return C$1.currentNode = r$3, e;
485
+ return C$1.currentNode = r$2, e;
473
486
  }
474
487
  p(t) {
475
488
  let i = 0;
476
- for (const s of this._$AV) undefined !== s && (undefined !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
489
+ for (const s of this._$AV) void 0 !== s && (void 0 !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
477
490
  }
478
491
  };
479
492
  class R {
@@ -481,12 +494,12 @@
481
494
  return this._$AM?._$AU ?? this._$Cv;
482
495
  }
483
496
  constructor(t, i, s, e) {
484
- this.type = 2, this._$AH = E$1, this._$AN = undefined, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
497
+ this.type = 2, this._$AH = E$1, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
485
498
  }
486
499
  get parentNode() {
487
500
  let t = this._$AA.parentNode;
488
501
  const i = this._$AM;
489
- return undefined !== i && 11 === t?.nodeType && (t = i.parentNode), t;
502
+ return void 0 !== i && 11 === t?.nodeType && (t = i.parentNode), t;
490
503
  }
491
504
  get startNode() {
492
505
  return this._$AA;
@@ -495,7 +508,7 @@
495
508
  return this._$AB;
496
509
  }
497
510
  _$AI(t, i = this) {
498
- t = S(this, t, i), c$4(t) ? t === E$1 || null == t || "" === t ? (this._$AH !== E$1 && this._$AR(), this._$AH = E$1) : t !== this._$AH && t !== T && this._(t) : undefined !== t._$litType$ ? this.$(t) : undefined !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
511
+ t = S(this, t, i), c$4(t) ? t === E$1 || null == t || "" === t ? (this._$AH !== E$1 && this._$AR(), this._$AH = E$1) : t !== this._$AH && t !== T && this._(t) : void 0 !== t._$litType$ ? this.$(t) : void 0 !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
499
512
  }
500
513
  O(t) {
501
514
  return this._$AA.parentNode.insertBefore(t, this._$AB);
@@ -504,14 +517,14 @@
504
517
  this._$AH !== t && (this._$AR(), this._$AH = this.O(t));
505
518
  }
506
519
  _(t) {
507
- this._$AH !== E$1 && c$4(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r$3.createTextNode(t)), this._$AH = t;
520
+ this._$AH !== E$1 && c$4(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r$2.createTextNode(t)), this._$AH = t;
508
521
  }
509
522
  $(t) {
510
523
  const {
511
524
  values: i,
512
525
  _$litType$: s
513
526
  } = t,
514
- e = "number" == typeof s ? this._$AC(t) : (undefined === s.el && (s.el = N$1.createElement(P(s.h, s.h[0]), this.options)), s);
527
+ e = "number" == typeof s ? this._$AC(t) : (void 0 === s.el && (s.el = N$1.createElement(P(s.h, s.h[0]), this.options)), s);
515
528
  if (this._$AH?._$AD === e) this._$AH.p(i);else {
516
529
  const t = new M$1(e, this),
517
530
  s = t.u(this.options);
@@ -520,7 +533,7 @@
520
533
  }
521
534
  _$AC(t) {
522
535
  let i = A$2.get(t.strings);
523
- return undefined === i && A$2.set(t.strings, i = new N$1(t)), i;
536
+ return void 0 === i && A$2.set(t.strings, i = new N$1(t)), i;
524
537
  }
525
538
  k(t) {
526
539
  a$2(this._$AH) || (this._$AH = [], this._$AR());
@@ -531,13 +544,13 @@
531
544
  e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
532
545
  }
533
546
  _$AR(t = this._$AA.nextSibling, i) {
534
- for (this._$AP?.(false, true, i); t && t !== this._$AB;) {
547
+ for (this._$AP?.(false, true, i); t !== this._$AB;) {
535
548
  const i = t.nextSibling;
536
549
  t.remove(), t = i;
537
550
  }
538
551
  }
539
552
  setConnected(t) {
540
- undefined === this._$AM && (this._$Cv = t, this._$AP?.(t));
553
+ void 0 === this._$AM && (this._$Cv = t, this._$AP?.(t));
541
554
  }
542
555
  }
543
556
  let k$1 = class k {
@@ -548,12 +561,12 @@
548
561
  return this._$AM._$AU;
549
562
  }
550
563
  constructor(t, i, s, e, h) {
551
- this.type = 1, this._$AH = E$1, this._$AN = undefined, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E$1;
564
+ this.type = 1, this._$AH = E$1, this._$AN = void 0, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E$1;
552
565
  }
553
566
  _$AI(t, i = this, s, e) {
554
567
  const h = this.strings;
555
568
  let o = false;
556
- if (undefined === h) t = S(this, t, i, 0), o = !c$4(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
569
+ if (void 0 === h) t = S(this, t, i, 0), o = !c$4(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
557
570
  const e = t;
558
571
  let n, r;
559
572
  for (t = h[0], n = 0; n < h.length - 1; n++) r = S(this, e[s + n], i, n), r === T && (r = this._$AH[n]), o ||= !c$4(r) || r !== this._$AH[n], r === E$1 ? t = E$1 : t !== E$1 && (t += (r ?? "") + h[n + 1]), this._$AH[n] = r;
@@ -569,7 +582,7 @@
569
582
  super(...arguments), this.type = 3;
570
583
  }
571
584
  j(t) {
572
- this.element[this.name] = t === E$1 ? undefined : t;
585
+ this.element[this.name] = t === E$1 ? void 0 : t;
573
586
  }
574
587
  }
575
588
  class I extends k$1 {
@@ -597,7 +610,7 @@
597
610
  }
598
611
  class z {
599
612
  constructor(t, i, s) {
600
- this.element = t, this.type = 6, this._$AN = undefined, this._$AM = i, this.options = s;
613
+ this.element = t, this.type = 6, this._$AN = void 0, this._$AM = i, this.options = s;
601
614
  }
602
615
  get _$AU() {
603
616
  return this._$AM._$AU;
@@ -607,13 +620,13 @@
607
620
  }
608
621
  }
609
622
  const j$1 = t$1.litHtmlPolyfillSupport;
610
- j$1?.(N$1, R), (t$1.litHtmlVersions ??= []).push("3.2.1");
623
+ j$1?.(N$1, R), (t$1.litHtmlVersions ??= []).push("3.3.1");
611
624
  const B$1 = (t, i, s) => {
612
625
  const e = s?.renderBefore ?? i;
613
626
  let h = e._$litPart$;
614
- if (undefined === h) {
627
+ if (void 0 === h) {
615
628
  const t = s?.renderBefore ?? null;
616
- e._$litPart$ = h = new R(i.insertBefore(l(), t), t, undefined, s ?? {});
629
+ e._$litPart$ = h = new R(i.insertBefore(l(), t), t, void 0, s ?? {});
617
630
  }
618
631
  return h._$AI(t), h;
619
632
  };
@@ -623,19 +636,20 @@
623
636
  * Copyright 2017 Google LLC
624
637
  * SPDX-License-Identifier: BSD-3-Clause
625
638
  */
626
- let r$2 = class r extends b$2 {
639
+ const s$2 = globalThis;
640
+ let i$2 = class i extends y$2 {
627
641
  constructor() {
628
642
  super(...arguments), this.renderOptions = {
629
643
  host: this
630
- }, this._$Do = undefined;
644
+ }, this._$Do = void 0;
631
645
  }
632
646
  createRenderRoot() {
633
647
  const t = super.createRenderRoot();
634
648
  return this.renderOptions.renderBefore ??= t.firstChild, t;
635
649
  }
636
650
  update(t) {
637
- const s = this.render();
638
- this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B$1(s, this.renderRoot, this.renderOptions);
651
+ const r = this.render();
652
+ this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B$1(r, this.renderRoot, this.renderOptions);
639
653
  }
640
654
  connectedCallback() {
641
655
  super.connectedCallback(), this._$Do?.setConnected(true);
@@ -647,14 +661,14 @@
647
661
  return T;
648
662
  }
649
663
  };
650
- r$2._$litElement$ = true, r$2["finalized"] = true, globalThis.litElementHydrateSupport?.({
651
- LitElement: r$2
664
+ i$2._$litElement$ = true, i$2["finalized"] = true, s$2.litElementHydrateSupport?.({
665
+ LitElement: i$2
652
666
  });
653
- const i$2 = globalThis.litElementPolyfillSupport;
654
- i$2?.({
655
- LitElement: r$2
667
+ const o$3 = s$2.litElementPolyfillSupport;
668
+ o$3?.({
669
+ LitElement: i$2
656
670
  });
657
- (globalThis.litElementVersions ??= []).push("4.1.1");
671
+ (s$2.litElementVersions ??= []).push("4.2.1");
658
672
 
659
673
  function ascending$1(a, b) {
660
674
  return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
@@ -5440,7 +5454,7 @@
5440
5454
  // from the point to the South pole. If it is zero, then the point is the
5441
5455
  // same side as the South pole.
5442
5456
 
5443
- return (angle < -1e-6 || angle < epsilon$1 && sum < -1e-12) ^ winding & 1;
5457
+ return (angle < -epsilon$1 || angle < epsilon$1 && sum < -epsilon2) ^ winding & 1;
5444
5458
  }
5445
5459
 
5446
5460
  function clip (pointVisible, clipLine, interpolate, start) {
@@ -5857,7 +5871,7 @@
5857
5871
  }
5858
5872
 
5859
5873
  var clipMax = 1e9,
5860
- clipMin = -1e9;
5874
+ clipMin = -clipMax;
5861
5875
 
5862
5876
  // TODO Use d3-polygon’s polygonContains here for the ring check?
5863
5877
  // TODO Eliminate duplicate buffering in clipBuffer and polygon.push?
@@ -8754,7 +8768,7 @@
8754
8768
  return initInterpolator.apply(scale, arguments);
8755
8769
  }
8756
8770
 
8757
- function colors (specifier) {
8771
+ function colors$1 (specifier) {
8758
8772
  var n = specifier.length / 6 | 0,
8759
8773
  colors = new Array(n),
8760
8774
  i = 0;
@@ -8762,109 +8776,109 @@
8762
8776
  return colors;
8763
8777
  }
8764
8778
 
8765
- var schemeCategory10 = colors("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");
8779
+ var schemeCategory10 = colors$1("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");
8766
8780
 
8767
- var schemeAccent = colors("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666");
8781
+ var schemeAccent = colors$1("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666");
8768
8782
 
8769
- var schemeDark2 = colors("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666");
8783
+ var schemeDark2 = colors$1("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666");
8770
8784
 
8771
- var schemeObservable10 = colors("4269d0efb118ff725c6cc5b03ca951ff8ab7a463f297bbf59c6b4e9498a0");
8785
+ var schemeObservable10 = colors$1("4269d0efb118ff725c6cc5b03ca951ff8ab7a463f297bbf59c6b4e9498a0");
8772
8786
 
8773
- var schemePaired = colors("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928");
8787
+ var schemePaired = colors$1("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928");
8774
8788
 
8775
- var schemePastel1 = colors("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2");
8789
+ var schemePastel1 = colors$1("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2");
8776
8790
 
8777
- var schemePastel2 = colors("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc");
8791
+ var schemePastel2 = colors$1("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc");
8778
8792
 
8779
- var schemeSet1 = colors("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999");
8793
+ var schemeSet1 = colors$1("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999");
8780
8794
 
8781
- var schemeSet2 = colors("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3");
8795
+ var schemeSet2 = colors$1("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3");
8782
8796
 
8783
- var schemeSet3 = colors("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");
8797
+ var schemeSet3 = colors$1("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");
8784
8798
 
8785
- var schemeTableau10 = colors("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");
8799
+ var schemeTableau10 = colors$1("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");
8786
8800
 
8787
8801
  var ramp$1 = scheme => rgbBasis(scheme[scheme.length - 1]);
8788
8802
 
8789
- var scheme$q = new Array(3).concat("d8b365f5f5f55ab4ac", "a6611adfc27d80cdc1018571", "a6611adfc27df5f5f580cdc1018571", "8c510ad8b365f6e8c3c7eae55ab4ac01665e", "8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e", "8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e", "8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e", "5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30", "5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(colors);
8803
+ var scheme$q = new Array(3).concat("d8b365f5f5f55ab4ac", "a6611adfc27d80cdc1018571", "a6611adfc27df5f5f580cdc1018571", "8c510ad8b365f6e8c3c7eae55ab4ac01665e", "8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e", "8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e", "8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e", "5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30", "5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(colors$1);
8790
8804
  var interpolateBrBG = ramp$1(scheme$q);
8791
8805
 
8792
- var scheme$p = new Array(3).concat("af8dc3f7f7f77fbf7b", "7b3294c2a5cfa6dba0008837", "7b3294c2a5cff7f7f7a6dba0008837", "762a83af8dc3e7d4e8d9f0d37fbf7b1b7837", "762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837", "762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837", "762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837", "40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b", "40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(colors);
8806
+ var scheme$p = new Array(3).concat("af8dc3f7f7f77fbf7b", "7b3294c2a5cfa6dba0008837", "7b3294c2a5cff7f7f7a6dba0008837", "762a83af8dc3e7d4e8d9f0d37fbf7b1b7837", "762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837", "762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837", "762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837", "40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b", "40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(colors$1);
8793
8807
  var interpolatePRGn = ramp$1(scheme$p);
8794
8808
 
8795
- var scheme$o = new Array(3).concat("e9a3c9f7f7f7a1d76a", "d01c8bf1b6dab8e1864dac26", "d01c8bf1b6daf7f7f7b8e1864dac26", "c51b7de9a3c9fde0efe6f5d0a1d76a4d9221", "c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221", "c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221", "c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221", "8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419", "8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(colors);
8809
+ var scheme$o = new Array(3).concat("e9a3c9f7f7f7a1d76a", "d01c8bf1b6dab8e1864dac26", "d01c8bf1b6daf7f7f7b8e1864dac26", "c51b7de9a3c9fde0efe6f5d0a1d76a4d9221", "c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221", "c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221", "c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221", "8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419", "8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(colors$1);
8796
8810
  var interpolatePiYG = ramp$1(scheme$o);
8797
8811
 
8798
- var scheme$n = new Array(3).concat("998ec3f7f7f7f1a340", "5e3c99b2abd2fdb863e66101", "5e3c99b2abd2f7f7f7fdb863e66101", "542788998ec3d8daebfee0b6f1a340b35806", "542788998ec3d8daebf7f7f7fee0b6f1a340b35806", "5427888073acb2abd2d8daebfee0b6fdb863e08214b35806", "5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806", "2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08", "2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(colors);
8812
+ var scheme$n = new Array(3).concat("998ec3f7f7f7f1a340", "5e3c99b2abd2fdb863e66101", "5e3c99b2abd2f7f7f7fdb863e66101", "542788998ec3d8daebfee0b6f1a340b35806", "542788998ec3d8daebf7f7f7fee0b6f1a340b35806", "5427888073acb2abd2d8daebfee0b6fdb863e08214b35806", "5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806", "2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08", "2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(colors$1);
8799
8813
  var interpolatePuOr = ramp$1(scheme$n);
8800
8814
 
8801
- var scheme$m = new Array(3).concat("ef8a62f7f7f767a9cf", "ca0020f4a58292c5de0571b0", "ca0020f4a582f7f7f792c5de0571b0", "b2182bef8a62fddbc7d1e5f067a9cf2166ac", "b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac", "b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac", "b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac", "67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061", "67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(colors);
8815
+ var scheme$m = new Array(3).concat("ef8a62f7f7f767a9cf", "ca0020f4a58292c5de0571b0", "ca0020f4a582f7f7f792c5de0571b0", "b2182bef8a62fddbc7d1e5f067a9cf2166ac", "b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac", "b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac", "b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac", "67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061", "67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(colors$1);
8802
8816
  var interpolateRdBu = ramp$1(scheme$m);
8803
8817
 
8804
- var scheme$l = new Array(3).concat("ef8a62ffffff999999", "ca0020f4a582bababa404040", "ca0020f4a582ffffffbababa404040", "b2182bef8a62fddbc7e0e0e09999994d4d4d", "b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d", "b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d", "b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d", "67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a", "67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(colors);
8818
+ var scheme$l = new Array(3).concat("ef8a62ffffff999999", "ca0020f4a582bababa404040", "ca0020f4a582ffffffbababa404040", "b2182bef8a62fddbc7e0e0e09999994d4d4d", "b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d", "b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d", "b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d", "67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a", "67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(colors$1);
8805
8819
  var interpolateRdGy = ramp$1(scheme$l);
8806
8820
 
8807
- var scheme$k = new Array(3).concat("fc8d59ffffbf91bfdb", "d7191cfdae61abd9e92c7bb6", "d7191cfdae61ffffbfabd9e92c7bb6", "d73027fc8d59fee090e0f3f891bfdb4575b4", "d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4", "d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4", "d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4", "a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695", "a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(colors);
8821
+ var scheme$k = new Array(3).concat("fc8d59ffffbf91bfdb", "d7191cfdae61abd9e92c7bb6", "d7191cfdae61ffffbfabd9e92c7bb6", "d73027fc8d59fee090e0f3f891bfdb4575b4", "d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4", "d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4", "d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4", "a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695", "a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(colors$1);
8808
8822
  var interpolateRdYlBu = ramp$1(scheme$k);
8809
8823
 
8810
- var scheme$j = new Array(3).concat("fc8d59ffffbf91cf60", "d7191cfdae61a6d96a1a9641", "d7191cfdae61ffffbfa6d96a1a9641", "d73027fc8d59fee08bd9ef8b91cf601a9850", "d73027fc8d59fee08bffffbfd9ef8b91cf601a9850", "d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850", "d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850", "a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837", "a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(colors);
8824
+ var scheme$j = new Array(3).concat("fc8d59ffffbf91cf60", "d7191cfdae61a6d96a1a9641", "d7191cfdae61ffffbfa6d96a1a9641", "d73027fc8d59fee08bd9ef8b91cf601a9850", "d73027fc8d59fee08bffffbfd9ef8b91cf601a9850", "d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850", "d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850", "a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837", "a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(colors$1);
8811
8825
  var interpolateRdYlGn = ramp$1(scheme$j);
8812
8826
 
8813
- var scheme$i = new Array(3).concat("fc8d59ffffbf99d594", "d7191cfdae61abdda42b83ba", "d7191cfdae61ffffbfabdda42b83ba", "d53e4ffc8d59fee08be6f59899d5943288bd", "d53e4ffc8d59fee08bffffbfe6f59899d5943288bd", "d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd", "d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd", "9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2", "9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(colors);
8827
+ var scheme$i = new Array(3).concat("fc8d59ffffbf99d594", "d7191cfdae61abdda42b83ba", "d7191cfdae61ffffbfabdda42b83ba", "d53e4ffc8d59fee08be6f59899d5943288bd", "d53e4ffc8d59fee08bffffbfe6f59899d5943288bd", "d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd", "d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd", "9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2", "9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(colors$1);
8814
8828
  var interpolateSpectral = ramp$1(scheme$i);
8815
8829
 
8816
- var scheme$h = new Array(3).concat("e5f5f999d8c92ca25f", "edf8fbb2e2e266c2a4238b45", "edf8fbb2e2e266c2a42ca25f006d2c", "edf8fbccece699d8c966c2a42ca25f006d2c", "edf8fbccece699d8c966c2a441ae76238b45005824", "f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824", "f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(colors);
8830
+ var scheme$h = new Array(3).concat("e5f5f999d8c92ca25f", "edf8fbb2e2e266c2a4238b45", "edf8fbb2e2e266c2a42ca25f006d2c", "edf8fbccece699d8c966c2a42ca25f006d2c", "edf8fbccece699d8c966c2a441ae76238b45005824", "f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824", "f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(colors$1);
8817
8831
  var interpolateBuGn = ramp$1(scheme$h);
8818
8832
 
8819
- var scheme$g = new Array(3).concat("e0ecf49ebcda8856a7", "edf8fbb3cde38c96c688419d", "edf8fbb3cde38c96c68856a7810f7c", "edf8fbbfd3e69ebcda8c96c68856a7810f7c", "edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b", "f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b", "f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(colors);
8833
+ var scheme$g = new Array(3).concat("e0ecf49ebcda8856a7", "edf8fbb3cde38c96c688419d", "edf8fbb3cde38c96c68856a7810f7c", "edf8fbbfd3e69ebcda8c96c68856a7810f7c", "edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b", "f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b", "f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(colors$1);
8820
8834
  var interpolateBuPu = ramp$1(scheme$g);
8821
8835
 
8822
- var scheme$f = new Array(3).concat("e0f3dba8ddb543a2ca", "f0f9e8bae4bc7bccc42b8cbe", "f0f9e8bae4bc7bccc443a2ca0868ac", "f0f9e8ccebc5a8ddb57bccc443a2ca0868ac", "f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e", "f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e", "f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(colors);
8836
+ var scheme$f = new Array(3).concat("e0f3dba8ddb543a2ca", "f0f9e8bae4bc7bccc42b8cbe", "f0f9e8bae4bc7bccc443a2ca0868ac", "f0f9e8ccebc5a8ddb57bccc443a2ca0868ac", "f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e", "f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e", "f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(colors$1);
8823
8837
  var interpolateGnBu = ramp$1(scheme$f);
8824
8838
 
8825
- var scheme$e = new Array(3).concat("fee8c8fdbb84e34a33", "fef0d9fdcc8afc8d59d7301f", "fef0d9fdcc8afc8d59e34a33b30000", "fef0d9fdd49efdbb84fc8d59e34a33b30000", "fef0d9fdd49efdbb84fc8d59ef6548d7301f990000", "fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000", "fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(colors);
8839
+ var scheme$e = new Array(3).concat("fee8c8fdbb84e34a33", "fef0d9fdcc8afc8d59d7301f", "fef0d9fdcc8afc8d59e34a33b30000", "fef0d9fdd49efdbb84fc8d59e34a33b30000", "fef0d9fdd49efdbb84fc8d59ef6548d7301f990000", "fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000", "fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(colors$1);
8826
8840
  var interpolateOrRd = ramp$1(scheme$e);
8827
8841
 
8828
- var scheme$d = new Array(3).concat("ece2f0a6bddb1c9099", "f6eff7bdc9e167a9cf02818a", "f6eff7bdc9e167a9cf1c9099016c59", "f6eff7d0d1e6a6bddb67a9cf1c9099016c59", "f6eff7d0d1e6a6bddb67a9cf3690c002818a016450", "fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450", "fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(colors);
8842
+ var scheme$d = new Array(3).concat("ece2f0a6bddb1c9099", "f6eff7bdc9e167a9cf02818a", "f6eff7bdc9e167a9cf1c9099016c59", "f6eff7d0d1e6a6bddb67a9cf1c9099016c59", "f6eff7d0d1e6a6bddb67a9cf3690c002818a016450", "fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450", "fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(colors$1);
8829
8843
  var interpolatePuBuGn = ramp$1(scheme$d);
8830
8844
 
8831
- var scheme$c = new Array(3).concat("ece7f2a6bddb2b8cbe", "f1eef6bdc9e174a9cf0570b0", "f1eef6bdc9e174a9cf2b8cbe045a8d", "f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d", "f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b", "fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b", "fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(colors);
8845
+ var scheme$c = new Array(3).concat("ece7f2a6bddb2b8cbe", "f1eef6bdc9e174a9cf0570b0", "f1eef6bdc9e174a9cf2b8cbe045a8d", "f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d", "f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b", "fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b", "fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(colors$1);
8832
8846
  var interpolatePuBu = ramp$1(scheme$c);
8833
8847
 
8834
- var scheme$b = new Array(3).concat("e7e1efc994c7dd1c77", "f1eef6d7b5d8df65b0ce1256", "f1eef6d7b5d8df65b0dd1c77980043", "f1eef6d4b9dac994c7df65b0dd1c77980043", "f1eef6d4b9dac994c7df65b0e7298ace125691003f", "f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f", "f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(colors);
8848
+ var scheme$b = new Array(3).concat("e7e1efc994c7dd1c77", "f1eef6d7b5d8df65b0ce1256", "f1eef6d7b5d8df65b0dd1c77980043", "f1eef6d4b9dac994c7df65b0dd1c77980043", "f1eef6d4b9dac994c7df65b0e7298ace125691003f", "f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f", "f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(colors$1);
8835
8849
  var interpolatePuRd = ramp$1(scheme$b);
8836
8850
 
8837
- var scheme$a = new Array(3).concat("fde0ddfa9fb5c51b8a", "feebe2fbb4b9f768a1ae017e", "feebe2fbb4b9f768a1c51b8a7a0177", "feebe2fcc5c0fa9fb5f768a1c51b8a7a0177", "feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177", "fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177", "fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(colors);
8851
+ var scheme$a = new Array(3).concat("fde0ddfa9fb5c51b8a", "feebe2fbb4b9f768a1ae017e", "feebe2fbb4b9f768a1c51b8a7a0177", "feebe2fcc5c0fa9fb5f768a1c51b8a7a0177", "feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177", "fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177", "fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(colors$1);
8838
8852
  var interpolateRdPu = ramp$1(scheme$a);
8839
8853
 
8840
- var scheme$9 = new Array(3).concat("edf8b17fcdbb2c7fb8", "ffffcca1dab441b6c4225ea8", "ffffcca1dab441b6c42c7fb8253494", "ffffccc7e9b47fcdbb41b6c42c7fb8253494", "ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84", "ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84", "ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(colors);
8854
+ var scheme$9 = new Array(3).concat("edf8b17fcdbb2c7fb8", "ffffcca1dab441b6c4225ea8", "ffffcca1dab441b6c42c7fb8253494", "ffffccc7e9b47fcdbb41b6c42c7fb8253494", "ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84", "ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84", "ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(colors$1);
8841
8855
  var interpolateYlGnBu = ramp$1(scheme$9);
8842
8856
 
8843
- var scheme$8 = new Array(3).concat("f7fcb9addd8e31a354", "ffffccc2e69978c679238443", "ffffccc2e69978c67931a354006837", "ffffccd9f0a3addd8e78c67931a354006837", "ffffccd9f0a3addd8e78c67941ab5d238443005a32", "ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32", "ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(colors);
8857
+ var scheme$8 = new Array(3).concat("f7fcb9addd8e31a354", "ffffccc2e69978c679238443", "ffffccc2e69978c67931a354006837", "ffffccd9f0a3addd8e78c67931a354006837", "ffffccd9f0a3addd8e78c67941ab5d238443005a32", "ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32", "ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(colors$1);
8844
8858
  var interpolateYlGn = ramp$1(scheme$8);
8845
8859
 
8846
- var scheme$7 = new Array(3).concat("fff7bcfec44fd95f0e", "ffffd4fed98efe9929cc4c02", "ffffd4fed98efe9929d95f0e993404", "ffffd4fee391fec44ffe9929d95f0e993404", "ffffd4fee391fec44ffe9929ec7014cc4c028c2d04", "ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04", "ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(colors);
8860
+ var scheme$7 = new Array(3).concat("fff7bcfec44fd95f0e", "ffffd4fed98efe9929cc4c02", "ffffd4fed98efe9929d95f0e993404", "ffffd4fee391fec44ffe9929d95f0e993404", "ffffd4fee391fec44ffe9929ec7014cc4c028c2d04", "ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04", "ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(colors$1);
8847
8861
  var interpolateYlOrBr = ramp$1(scheme$7);
8848
8862
 
8849
- var scheme$6 = new Array(3).concat("ffeda0feb24cf03b20", "ffffb2fecc5cfd8d3ce31a1c", "ffffb2fecc5cfd8d3cf03b20bd0026", "ffffb2fed976feb24cfd8d3cf03b20bd0026", "ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026", "ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026", "ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(colors);
8863
+ var scheme$6 = new Array(3).concat("ffeda0feb24cf03b20", "ffffb2fecc5cfd8d3ce31a1c", "ffffb2fecc5cfd8d3cf03b20bd0026", "ffffb2fed976feb24cfd8d3cf03b20bd0026", "ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026", "ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026", "ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(colors$1);
8850
8864
  var interpolateYlOrRd = ramp$1(scheme$6);
8851
8865
 
8852
- var scheme$5 = new Array(3).concat("deebf79ecae13182bd", "eff3ffbdd7e76baed62171b5", "eff3ffbdd7e76baed63182bd08519c", "eff3ffc6dbef9ecae16baed63182bd08519c", "eff3ffc6dbef9ecae16baed64292c62171b5084594", "f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594", "f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(colors);
8866
+ var scheme$5 = new Array(3).concat("deebf79ecae13182bd", "eff3ffbdd7e76baed62171b5", "eff3ffbdd7e76baed63182bd08519c", "eff3ffc6dbef9ecae16baed63182bd08519c", "eff3ffc6dbef9ecae16baed64292c62171b5084594", "f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594", "f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(colors$1);
8853
8867
  var interpolateBlues = ramp$1(scheme$5);
8854
8868
 
8855
- var scheme$4 = new Array(3).concat("e5f5e0a1d99b31a354", "edf8e9bae4b374c476238b45", "edf8e9bae4b374c47631a354006d2c", "edf8e9c7e9c0a1d99b74c47631a354006d2c", "edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32", "f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32", "f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(colors);
8869
+ var scheme$4 = new Array(3).concat("e5f5e0a1d99b31a354", "edf8e9bae4b374c476238b45", "edf8e9bae4b374c47631a354006d2c", "edf8e9c7e9c0a1d99b74c47631a354006d2c", "edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32", "f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32", "f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(colors$1);
8856
8870
  var interpolateGreens = ramp$1(scheme$4);
8857
8871
 
8858
- var scheme$3 = new Array(3).concat("f0f0f0bdbdbd636363", "f7f7f7cccccc969696525252", "f7f7f7cccccc969696636363252525", "f7f7f7d9d9d9bdbdbd969696636363252525", "f7f7f7d9d9d9bdbdbd969696737373525252252525", "fffffff0f0f0d9d9d9bdbdbd969696737373525252252525", "fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(colors);
8872
+ var scheme$3 = new Array(3).concat("f0f0f0bdbdbd636363", "f7f7f7cccccc969696525252", "f7f7f7cccccc969696636363252525", "f7f7f7d9d9d9bdbdbd969696636363252525", "f7f7f7d9d9d9bdbdbd969696737373525252252525", "fffffff0f0f0d9d9d9bdbdbd969696737373525252252525", "fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(colors$1);
8859
8873
  var interpolateGreys = ramp$1(scheme$3);
8860
8874
 
8861
- var scheme$2 = new Array(3).concat("efedf5bcbddc756bb1", "f2f0f7cbc9e29e9ac86a51a3", "f2f0f7cbc9e29e9ac8756bb154278f", "f2f0f7dadaebbcbddc9e9ac8756bb154278f", "f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486", "fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486", "fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(colors);
8875
+ var scheme$2 = new Array(3).concat("efedf5bcbddc756bb1", "f2f0f7cbc9e29e9ac86a51a3", "f2f0f7cbc9e29e9ac8756bb154278f", "f2f0f7dadaebbcbddc9e9ac8756bb154278f", "f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486", "fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486", "fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(colors$1);
8862
8876
  var interpolatePurples = ramp$1(scheme$2);
8863
8877
 
8864
- var scheme$1 = new Array(3).concat("fee0d2fc9272de2d26", "fee5d9fcae91fb6a4acb181d", "fee5d9fcae91fb6a4ade2d26a50f15", "fee5d9fcbba1fc9272fb6a4ade2d26a50f15", "fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d", "fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d", "fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(colors);
8878
+ var scheme$1 = new Array(3).concat("fee0d2fc9272de2d26", "fee5d9fcae91fb6a4acb181d", "fee5d9fcae91fb6a4ade2d26a50f15", "fee5d9fcbba1fc9272fb6a4ade2d26a50f15", "fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d", "fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d", "fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(colors$1);
8865
8879
  var interpolateReds = ramp$1(scheme$1);
8866
8880
 
8867
- var scheme = new Array(3).concat("fee6cefdae6be6550d", "feeddefdbe85fd8d3cd94701", "feeddefdbe85fd8d3ce6550da63603", "feeddefdd0a2fdae6bfd8d3ce6550da63603", "feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04", "fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04", "fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(colors);
8881
+ var scheme = new Array(3).concat("fee6cefdae6be6550d", "feeddefdbe85fd8d3cd94701", "feeddefdbe85fd8d3ce6550da63603", "feeddefdd0a2fdae6bfd8d3ce6550da63603", "feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04", "fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04", "fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(colors$1);
8868
8882
  var interpolateOranges = ramp$1(scheme);
8869
8883
 
8870
8884
  function interpolateCividis (t) {
@@ -8909,10 +8923,10 @@
8909
8923
  return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];
8910
8924
  };
8911
8925
  }
8912
- var interpolateViridis = ramp(colors("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));
8913
- var magma = ramp(colors("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf"));
8914
- var inferno = ramp(colors("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4"));
8915
- var plasma = ramp(colors("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));
8926
+ var interpolateViridis = ramp(colors$1("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));
8927
+ var magma = ramp(colors$1("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf"));
8928
+ var inferno = ramp(colors$1("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4"));
8929
+ var plasma = ramp(colors$1("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));
8916
8930
 
8917
8931
  function constant$1 (x) {
8918
8932
  return function constant() {
@@ -10176,7 +10190,7 @@
10176
10190
  DecidablesElement Base Class - Not intended for instantiation!
10177
10191
  <decidables-element>
10178
10192
  */
10179
- class DecidablesElement extends r$2 {
10193
+ class DecidablesElement extends i$2 {
10180
10194
  getComputedStyleValue(property) {
10181
10195
  return getComputedStyle(this).getPropertyValue(property).trim();
10182
10196
  }
@@ -10431,22 +10445,22 @@
10431
10445
  static get styles() {
10432
10446
  return i$5`
10433
10447
  :host {
10434
- ---shadow-0: var(--shadow-0, ${r$5(this.cssBoxShadow(0))});
10435
- ---shadow-2: var(--shadow-2, ${r$5(this.cssBoxShadow(2))});
10436
- ---shadow-4: var(--shadow-4, ${r$5(this.cssBoxShadow(4))});
10437
- ---shadow-8: var(--shadow-8, ${r$5(this.cssBoxShadow(8))});
10438
-
10439
- ---color-background: var(--color-background, ${r$5(this.greys.white)});
10440
- ---color-border: var(--color-border, ${r$5(this.greys.light75)});
10441
- ---color-text: var(--color-text, ${r$5(this.greys.dark75)});
10442
- ---color-text-inverse: var(--color-text-inverse, ${r$5(this.greys.white)});
10443
- ---color-link: var(--color-link, ${r$5(this.greys.dark25)});
10444
- ---color-element-background: var(--color-element-background, ${r$5(this.greys.light75)});
10445
- ---color-element-disabled: var(--color-element-disabled, ${r$5(this.greys.light50)});
10446
- ---color-element-enabled: var(--color-element-enabled, ${r$5(this.greys.dark25)});
10447
- ---color-element-selected: var(--color-element-selected, ${r$5(this.greys.grey)});
10448
- ---color-element-border: var(--color-element-border, ${r$5(this.greys.dark50)});
10449
- ---color-element-emphasis: var(--color-element-emphasis, ${r$5(this.greys.dark75)});
10448
+ ---shadow-0: var(--shadow-0, ${r$4(this.cssBoxShadow(0))});
10449
+ ---shadow-2: var(--shadow-2, ${r$4(this.cssBoxShadow(2))});
10450
+ ---shadow-4: var(--shadow-4, ${r$4(this.cssBoxShadow(4))});
10451
+ ---shadow-8: var(--shadow-8, ${r$4(this.cssBoxShadow(8))});
10452
+
10453
+ ---color-background: var(--color-background, ${r$4(this.greys.white)});
10454
+ ---color-border: var(--color-border, ${r$4(this.greys.light75)});
10455
+ ---color-text: var(--color-text, ${r$4(this.greys.dark75)});
10456
+ ---color-text-inverse: var(--color-text-inverse, ${r$4(this.greys.white)});
10457
+ ---color-link: var(--color-link, ${r$4(this.greys.dark25)});
10458
+ ---color-element-background: var(--color-element-background, ${r$4(this.greys.light75)});
10459
+ ---color-element-disabled: var(--color-element-disabled, ${r$4(this.greys.light50)});
10460
+ ---color-element-enabled: var(--color-element-enabled, ${r$4(this.greys.dark25)});
10461
+ ---color-element-selected: var(--color-element-selected, ${r$4(this.greys.grey)});
10462
+ ---color-element-border: var(--color-element-border, ${r$4(this.greys.dark50)});
10463
+ ---color-element-emphasis: var(--color-element-emphasis, ${r$4(this.greys.dark75)});
10450
10464
 
10451
10465
  ---font-family-base: var(--font-family-base, "Source Sans", sans-serif);
10452
10466
  ---font-family-math: var(--font-family-math, "Source Serif", serif);
@@ -10456,6 +10470,7 @@
10456
10470
  ---transition-duration: var(--transition-duration, 500ms);
10457
10471
 
10458
10472
  font-family: var(---font-family-base);
10473
+ font-weight: normal;
10459
10474
  }
10460
10475
 
10461
10476
  :host,
@@ -10677,9 +10692,9 @@
10677
10692
  ---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
10678
10693
  ---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
10679
10694
 
10680
- ---shadow-2-rotate: var(--shadow-2-rotate, ${r$5(this.cssBoxShadow(2, true, false))});
10681
- ---shadow-4-rotate: var(--shadow-4-rotate, ${r$5(this.cssBoxShadow(4, true, false))});
10682
- ---shadow-8-rotate: var(--shadow-8-rotate, ${r$5(this.cssBoxShadow(8, true, false))});
10695
+ ---shadow-2-rotate: var(--shadow-2-rotate, ${r$4(this.cssBoxShadow(2, true, false))});
10696
+ ---shadow-4-rotate: var(--shadow-4-rotate, ${r$4(this.cssBoxShadow(4, true, false))});
10697
+ ---shadow-8-rotate: var(--shadow-8-rotate, ${r$4(this.cssBoxShadow(8, true, false))});
10683
10698
 
10684
10699
  display: flex;
10685
10700
 
@@ -11182,7 +11197,6 @@
11182
11197
  padding: 0;
11183
11198
  margin: -1px;
11184
11199
  overflow: hidden;
11185
- clip: rect(0 0 0 0);
11186
11200
 
11187
11201
  white-space: nowrap;
11188
11202
 
@@ -11404,7 +11418,6 @@
11404
11418
  padding: 0;
11405
11419
  margin: -1px;
11406
11420
  overflow: hidden;
11407
- clip: rect(0 0 0 0);
11408
11421
 
11409
11422
  white-space: nowrap;
11410
11423
 
@@ -11540,6 +11553,18 @@
11540
11553
  };
11541
11554
  }
11542
11555
 
11556
+ var data = { colors:{ a:"#e41a1c",
11557
+ d:"#377eb8",
11558
+ k:"#4daf4a",
11559
+ v:"#984ea3",
11560
+ sooner:"#ff7f00",
11561
+ later:"#f781bf",
11562
+ larger:"#4545d0",
11563
+ smaller:"#f032e6",
11564
+ equal:"#10dbc9",
11565
+ nr:"#cccccc" } };
11566
+ var colors = data.colors;
11567
+
11543
11568
  /*
11544
11569
  DiscountableElement Base Class - Not intended for instantiation!
11545
11570
  <sdt-element>
@@ -11559,18 +11584,7 @@
11559
11584
  this.interactive = false;
11560
11585
  }
11561
11586
  static get colors() {
11562
- return {
11563
- a: schemeSet1[0],
11564
- d: schemeSet1[1],
11565
- k: schemeSet1[2],
11566
- v: schemeSet1[3],
11567
- sooner: schemeSet1[5],
11568
- later: schemeSet1[7],
11569
- larger: '#4545d0',
11570
- smaller: '#f032e6',
11571
- equal: '#10dbc9',
11572
- nr: '#cccccc'
11573
- };
11587
+ return colors;
11574
11588
  }
11575
11589
  static get lights() {
11576
11590
  return Object.keys(DiscountableElement.colors).reduce((acc, cur) => {
@@ -11587,38 +11601,38 @@
11587
11601
  static get styles() {
11588
11602
  return [super.styles, i$5`
11589
11603
  :host {
11590
- ---color-a: var(--color-a, ${r$5(this.colors.a)});
11591
- ---color-d: var(--color-d, ${r$5(this.colors.d)});
11592
- ---color-k: var(--color-k, ${r$5(this.colors.k)});
11593
- ---color-v: var(--color-v, ${r$5(this.colors.v)});
11594
- ---color-sooner: var(--color-sooner, ${r$5(this.colors.sooner)});
11595
- ---color-later: var(--color-later, ${r$5(this.colors.later)});
11596
- ---color-larger: var(--color-larger, ${r$5(this.colors.larger)});
11597
- ---color-smaller: var(--color-smaller, ${r$5(this.colors.smaller)});
11598
- ---color-equal: var(--color-equal, ${r$5(this.colors.equal)});
11599
- ---color-nr: var(--color-nr, ${r$5(this.colors.nr)});
11600
-
11601
- ---color-a-light: var(--color-a-light, ${r$5(this.lights.a)});
11602
- ---color-d-light: var(--color-d-light, ${r$5(this.lights.d)});
11603
- ---color-k-light: var(--color-k-light, ${r$5(this.lights.k)});
11604
- ---color-v-light: var(--color-v-light, ${r$5(this.lights.v)});
11605
- ---color-sooner-light: var(--color-sooner-light, ${r$5(this.lights.sooner)});
11606
- ---color-later-light: var(--color-later-light, ${r$5(this.lights.later)});
11607
- ---color-larger-light: var(--color-larger-light, ${r$5(this.lights.larger)});
11608
- ---color-smaller-light: var(--color-smaller-light, ${r$5(this.lights.smaller)});
11609
- ---color-equal-light: var(--color-equal-light, ${r$5(this.lights.equal)});
11610
- ---color-nr-light: var(--color-nr-light, ${r$5(this.lights.nr)});
11611
-
11612
- ---color-a-dark: var(--color-a-dark, ${r$5(this.darks.a)});
11613
- ---color-d-dark: var(--color-d-dark, ${r$5(this.darks.d)});
11614
- ---color-k-dark: var(--color-k-dark, ${r$5(this.darks.k)});
11615
- ---color-v-dark: var(--color-v-dark, ${r$5(this.darks.v)});
11616
- ---color-sooner-dark: var(--color-sooner-dark, ${r$5(this.darks.sooner)});
11617
- ---color-later-dark: var(--color-later-dark, ${r$5(this.darks.later)});
11618
- ---color-larger-dark: var(--color-larger-dark, ${r$5(this.darks.larger)});
11619
- ---color-smaller-dark: var(--color-smaller-dark, ${r$5(this.darks.smaller)});
11620
- ---color-equal-dark: var(--color-equal-dark, ${r$5(this.darks.equal)});
11621
- ---color-nr-dark: var(--color-nr-dark, ${r$5(this.darks.nr)});
11604
+ ---color-a: var(--color-a, ${r$4(this.colors.a)});
11605
+ ---color-d: var(--color-d, ${r$4(this.colors.d)});
11606
+ ---color-k: var(--color-k, ${r$4(this.colors.k)});
11607
+ ---color-v: var(--color-v, ${r$4(this.colors.v)});
11608
+ ---color-sooner: var(--color-sooner, ${r$4(this.colors.sooner)});
11609
+ ---color-later: var(--color-later, ${r$4(this.colors.later)});
11610
+ ---color-larger: var(--color-larger, ${r$4(this.colors.larger)});
11611
+ ---color-smaller: var(--color-smaller, ${r$4(this.colors.smaller)});
11612
+ ---color-equal: var(--color-equal, ${r$4(this.colors.equal)});
11613
+ ---color-nr: var(--color-nr, ${r$4(this.colors.nr)});
11614
+
11615
+ ---color-a-light: var(--color-a-light, ${r$4(this.lights.a)});
11616
+ ---color-d-light: var(--color-d-light, ${r$4(this.lights.d)});
11617
+ ---color-k-light: var(--color-k-light, ${r$4(this.lights.k)});
11618
+ ---color-v-light: var(--color-v-light, ${r$4(this.lights.v)});
11619
+ ---color-sooner-light: var(--color-sooner-light, ${r$4(this.lights.sooner)});
11620
+ ---color-later-light: var(--color-later-light, ${r$4(this.lights.later)});
11621
+ ---color-larger-light: var(--color-larger-light, ${r$4(this.lights.larger)});
11622
+ ---color-smaller-light: var(--color-smaller-light, ${r$4(this.lights.smaller)});
11623
+ ---color-equal-light: var(--color-equal-light, ${r$4(this.lights.equal)});
11624
+ ---color-nr-light: var(--color-nr-light, ${r$4(this.lights.nr)});
11625
+
11626
+ ---color-a-dark: var(--color-a-dark, ${r$4(this.darks.a)});
11627
+ ---color-d-dark: var(--color-d-dark, ${r$4(this.darks.d)});
11628
+ ---color-k-dark: var(--color-k-dark, ${r$4(this.darks.k)});
11629
+ ---color-v-dark: var(--color-v-dark, ${r$4(this.darks.v)});
11630
+ ---color-sooner-dark: var(--color-sooner-dark, ${r$4(this.darks.sooner)});
11631
+ ---color-later-dark: var(--color-later-dark, ${r$4(this.darks.later)});
11632
+ ---color-larger-dark: var(--color-larger-dark, ${r$4(this.darks.larger)});
11633
+ ---color-smaller-dark: var(--color-smaller-dark, ${r$4(this.darks.smaller)});
11634
+ ---color-equal-dark: var(--color-equal-dark, ${r$4(this.darks.equal)});
11635
+ ---color-nr-dark: var(--color-nr-dark, ${r$4(this.darks.nr)});
11622
11636
  }
11623
11637
  `];
11624
11638
  }
@@ -12051,7 +12065,7 @@
12051
12065
  * Copyright 2020 Google LLC
12052
12066
  * SPDX-License-Identifier: BSD-3-Clause
12053
12067
  */
12054
- const f$1 = o => undefined === o.strings;
12068
+ const f$1 = o => void 0 === o.strings;
12055
12069
 
12056
12070
  /**
12057
12071
  * @license
@@ -12060,31 +12074,31 @@
12060
12074
  */
12061
12075
  const s = (i, t) => {
12062
12076
  const e = i._$AN;
12063
- if (undefined === e) return false;
12077
+ if (void 0 === e) return false;
12064
12078
  for (const i of e) i._$AO?.(t, false), s(i, t);
12065
12079
  return true;
12066
12080
  },
12067
12081
  o$1 = i => {
12068
12082
  let t, e;
12069
12083
  do {
12070
- if (undefined === (t = i._$AM)) break;
12084
+ if (void 0 === (t = i._$AM)) break;
12071
12085
  e = t._$AN, e.delete(i), i = t;
12072
12086
  } while (0 === e?.size);
12073
12087
  },
12074
12088
  r$1 = i => {
12075
12089
  for (let t; t = i._$AM; i = t) {
12076
12090
  let e = t._$AN;
12077
- if (undefined === e) t._$AN = e = new Set();else if (e.has(i)) break;
12091
+ if (void 0 === e) t._$AN = e = new Set();else if (e.has(i)) break;
12078
12092
  e.add(i), c(t);
12079
12093
  }
12080
12094
  };
12081
12095
  function h(i) {
12082
- undefined !== this._$AN ? (o$1(this), this._$AM = i, r$1(this)) : this._$AM = i;
12096
+ void 0 !== this._$AN ? (o$1(this), this._$AM = i, r$1(this)) : this._$AM = i;
12083
12097
  }
12084
12098
  function n$1(i, t = false, e = 0) {
12085
12099
  const r = this._$AH,
12086
12100
  h = this._$AN;
12087
- if (undefined !== h && 0 !== h.size) if (t) {
12101
+ if (void 0 !== h && 0 !== h.size) if (t) {
12088
12102
  if (Array.isArray(r)) for (let i = e; i < r.length; i++) s(r[i], false), o$1(r[i]);else null != r && (s(r, false), o$1(r));
12089
12103
  } else s(this, i);
12090
12104
  }
@@ -12093,7 +12107,7 @@
12093
12107
  };
12094
12108
  class f extends i$1 {
12095
12109
  constructor() {
12096
- super(...arguments), this._$AN = undefined;
12110
+ super(...arguments), this._$AN = void 0;
12097
12111
  }
12098
12112
  _$AT(i, t, e) {
12099
12113
  super._$AT(i, t, e), r$1(this), this.isConnected = i._$AU;
@@ -12124,25 +12138,25 @@
12124
12138
  }],
12125
12139
  g = (t, i) => {
12126
12140
  const s = t - i;
12127
- return 0 === s ? undefined : s;
12141
+ return 0 === s ? void 0 : s;
12128
12142
  },
12129
12143
  w = (t, i) => {
12130
12144
  const s = t / i;
12131
- return 1 === s ? undefined : s;
12145
+ return 1 === s ? void 0 : s;
12132
12146
  },
12133
12147
  N = {
12134
12148
  left: (t, i) => {
12135
12149
  const s = g(t, i);
12136
12150
  return {
12137
12151
  value: s,
12138
- transform: null == s || isNaN(s) ? undefined : `translateX(${s}px)`
12152
+ transform: null == s || isNaN(s) ? void 0 : `translateX(${s}px)`
12139
12153
  };
12140
12154
  },
12141
12155
  top: (t, i) => {
12142
12156
  const s = g(t, i);
12143
12157
  return {
12144
12158
  value: s,
12145
- transform: null == s || isNaN(s) ? undefined : `translateY(${s}px)`
12159
+ transform: null == s || isNaN(s) ? void 0 : `translateY(${s}px)`
12146
12160
  };
12147
12161
  },
12148
12162
  width: (t, i) => {
@@ -12154,7 +12168,7 @@
12154
12168
  return {
12155
12169
  value: e,
12156
12170
  overrideFrom: s,
12157
- transform: null == e || isNaN(e) ? undefined : `scaleX(${e})`
12171
+ transform: null == e || isNaN(e) ? void 0 : `scaleX(${e})`
12158
12172
  };
12159
12173
  },
12160
12174
  height: (t, i) => {
@@ -12166,7 +12180,7 @@
12166
12180
  return {
12167
12181
  value: e,
12168
12182
  overrideFrom: s,
12169
- transform: null == e || isNaN(e) ? undefined : `scaleY(${e})`
12183
+ transform: null == e || isNaN(e) ? void 0 : `scaleY(${e})`
12170
12184
  };
12171
12185
  }
12172
12186
  },
@@ -12187,7 +12201,7 @@
12187
12201
  });
12188
12202
  }
12189
12203
  async resolveFinished() {
12190
- this.l?.(), this.l = undefined;
12204
+ this.l?.(), this.l = void 0;
12191
12205
  }
12192
12206
  render(i) {
12193
12207
  return E$1;
@@ -12199,13 +12213,13 @@
12199
12213
  return this.options.disabled || this.getController()?.disabled;
12200
12214
  }
12201
12215
  update(t, [i]) {
12202
- const s = undefined === this.u;
12216
+ const s = void 0 === this.u;
12203
12217
  return s && (this.u = t.options?.host, this.u.addController(this), this.u.updateComplete.then(t => this.t = true), this.element = t.element, j.set(this.element, this)), this.optionsOrCallback = i, (s || "function" != typeof i) && this.p(i), this.render(i);
12204
12218
  }
12205
12219
  p(t) {
12206
12220
  t = t ?? {};
12207
12221
  const i = this.getController();
12208
- undefined !== i && ((t = {
12222
+ void 0 !== i && ((t = {
12209
12223
  ...i.defaultOptions,
12210
12224
  ...t
12211
12225
  }).keyframeOptions = {
@@ -12218,7 +12232,7 @@
12218
12232
  i = this.element.getBoundingClientRect(),
12219
12233
  s = getComputedStyle(this.element);
12220
12234
  return this.options.properties.forEach(e => {
12221
- const h = i[e] ?? (N[e] ? undefined : s[e]),
12235
+ const h = i[e] ?? (N[e] ? void 0 : s[e]),
12222
12236
  o = Number(h);
12223
12237
  t[e] = isNaN(o) ? h + "" : o;
12224
12238
  }), t;
@@ -12243,7 +12257,7 @@
12243
12257
  const i = this.O(),
12244
12258
  s = this.j(this.options.keyframeOptions, i),
12245
12259
  e = this.m();
12246
- if (undefined !== this.A) {
12260
+ if (void 0 !== this.A) {
12247
12261
  const {
12248
12262
  from: s,
12249
12263
  to: h
@@ -12266,7 +12280,7 @@
12266
12280
  this.animate(t, s);
12267
12281
  }
12268
12282
  resetStyles() {
12269
- undefined !== this.P && (this.element.setAttribute("style", this.P ?? ""), this.P = undefined);
12283
+ void 0 !== this.P && (this.element.setAttribute("style", this.P ?? ""), this.P = void 0);
12270
12284
  }
12271
12285
  commitStyles() {
12272
12286
  this.P = this.element.getAttribute("style"), this.webAnimation?.commitStyles(), this.webAnimation?.cancel();
@@ -12274,7 +12288,7 @@
12274
12288
  reconnected() {}
12275
12289
  async disconnected() {
12276
12290
  if (!this.h) return;
12277
- if (undefined !== this.options.id && r.set(this.options.id, this.A), undefined === this.options.out) return;
12291
+ if (void 0 !== this.options.id && r.set(this.options.id, this.A), void 0 === this.options.out) return;
12278
12292
  if (this.prepare(), await a(), this.i?.isConnected) {
12279
12293
  const t = this.o && this.o.parentNode === this.i ? this.o : null;
12280
12294
  if (this.i.insertBefore(this.element, t), this.options.stabilizeOut) {
@@ -12295,7 +12309,7 @@
12295
12309
  this.options.onStart?.(this);
12296
12310
  }
12297
12311
  didFinish(t) {
12298
- t && this.options.onComplete?.(this), this.A = undefined, this.animatingProperties = undefined, this.frames = undefined, this.resolveFinished();
12312
+ t && this.options.onComplete?.(this), this.A = void 0, this.animatingProperties = void 0, this.frames = void 0, this.resolveFinished();
12299
12313
  }
12300
12314
  O() {
12301
12315
  const t = [];
@@ -12323,12 +12337,12 @@
12323
12337
  }, i = {
12324
12338
  ...i
12325
12339
  };
12326
- const e = s.map(t => t.animatingProperties).filter(t => undefined !== t);
12340
+ const e = s.map(t => t.animatingProperties).filter(t => void 0 !== t);
12327
12341
  let h = 1,
12328
12342
  o = 1;
12329
12343
  return e.length > 0 && (e.forEach(t => {
12330
12344
  t.width && (h /= t.width), t.height && (o /= t.height);
12331
- }), undefined !== t.left && undefined !== i.left && (t.left = h * t.left, i.left = h * i.left), undefined !== t.top && undefined !== i.top && (t.top = o * t.top, i.top = o * i.top)), {
12345
+ }), void 0 !== t.left && void 0 !== i.left && (t.left = h * t.left, i.left = h * i.left), void 0 !== t.top && void 0 !== i.top && (t.top = o * t.top, i.top = o * i.top)), {
12332
12346
  from: t,
12333
12347
  to: i
12334
12348
  };
@@ -12343,17 +12357,17 @@
12343
12357
  a = i[s];
12344
12358
  if (s in N) {
12345
12359
  const t = N[s];
12346
- if (undefined === n || undefined === a) continue;
12360
+ if (void 0 === n || void 0 === a) continue;
12347
12361
  const i = t(n, a);
12348
- undefined !== i.transform && (r[s] = i.value, o = true, e.transform = `${e.transform ?? ""} ${i.transform}`, undefined !== i.overrideFrom && Object.assign(e, i.overrideFrom));
12349
- } else n !== a && undefined !== n && undefined !== a && (o = true, e[s] = n, h[s] = a);
12362
+ void 0 !== i.transform && (r[s] = i.value, o = true, e.transform = `${e.transform ?? ""} ${i.transform}`, void 0 !== i.overrideFrom && Object.assign(e, i.overrideFrom));
12363
+ } else n !== a && void 0 !== n && void 0 !== a && (o = true, e[s] = n, h[s] = a);
12350
12364
  }
12351
- return e.transformOrigin = h.transformOrigin = s ? "center center" : "top left", this.animatingProperties = r, o ? [e, h] : undefined;
12365
+ return e.transformOrigin = h.transformOrigin = s ? "center center" : "top left", this.animatingProperties = r, o ? [e, h] : void 0;
12352
12366
  }
12353
12367
  async animate(t, i = this.options.keyframeOptions) {
12354
12368
  this.start(), this.frames = t;
12355
12369
  let s = false;
12356
- if (!this.isAnimating() && !this.isDisabled() && (this.options.onFrames && (this.frames = t = this.options.onFrames(this), this.log("modified frames", t)), undefined !== t)) {
12370
+ if (!this.isAnimating() && !this.isDisabled() && (this.options.onFrames && (this.frames = t = this.options.onFrames(this), this.log("modified frames", t)), void 0 !== t)) {
12357
12371
  this.log("animate", [t, i]), s = true, this.webAnimation = this.element.animate(t, i);
12358
12372
  const e = this.getController();
12359
12373
  e?.add(this);
@@ -13776,7 +13790,7 @@
13776
13790
 
13777
13791
  function format(date, fallback) {
13778
13792
  if (!(date instanceof Date)) date = new Date(+date);
13779
- if (isNaN(date)) return "string" === "function" ? fallback(date) : fallback;
13793
+ if (isNaN(date)) return typeof fallback === "function" ? fallback(date) : fallback;
13780
13794
  const hours = date.getUTCHours();
13781
13795
  const minutes = date.getUTCMinutes();
13782
13796
  const seconds = date.getUTCSeconds();
@@ -13792,7 +13806,7 @@
13792
13806
 
13793
13807
  const re = /^(?:[-+]\d{2})?\d{4}(?:-\d{2}(?:-\d{2})?)?(?:T\d{2}:\d{2}(?::\d{2}(?:\.\d{3})?)?(?:Z|[-+]\d{2}:?\d{2})?)?$/;
13794
13808
  function parse(string, fallback) {
13795
- if (!re.test(string += "")) return "undefined" === "function" ? fallback(string) : fallback;
13809
+ if (!re.test(string += "")) return typeof fallback === "function" ? fallback(string) : fallback;
13796
13810
  return new Date(string);
13797
13811
  }
13798
13812
 
@@ -14000,7 +14014,10 @@
14000
14014
  : isArrowVector(data) ? maybeTypedArrowify(data, type) : data instanceof type ? data : type.from(data, isNumberType(type) && !isNumberArray(data) ? coerceNumber : undefined);
14001
14015
  }
14002
14016
  function maybeTypedArrowify(vector, type) {
14003
- return vector == null ? vector : (type === undefined || type === Array) && isArrowDateType(vector.type) ? coerceDates(vector.toArray()) : maybeTypedArrayify(vector.toArray(), type);
14017
+ return vector == null ? vector : (type === undefined || type === Array) && isArrowDateType(vector.type) ? coerceDates(vectorToArray(vector)) : maybeTypedArrayify(vectorToArray(vector), type);
14018
+ }
14019
+ function vectorToArray(vector) {
14020
+ return vector.nullCount ? vector.toJSON() : vector.toArray();
14004
14021
  }
14005
14022
  const singleton = [null]; // for data-less decoration marks, e.g. frame
14006
14023
  const field = name => d => {
@@ -14093,11 +14110,24 @@
14093
14110
  function arrayify(values) {
14094
14111
  if (values == null || isArray(values)) return values;
14095
14112
  if (isArrowVector(values)) return maybeTypedArrowify(values);
14096
- switch (values.type) {
14113
+ if (isGeoJSON(values)) {
14114
+ switch (values.type) {
14115
+ case "FeatureCollection":
14116
+ return values.features;
14117
+ case "GeometryCollection":
14118
+ return values.geometries;
14119
+ default:
14120
+ return [values];
14121
+ }
14122
+ }
14123
+ return Array.from(values);
14124
+ }
14125
+
14126
+ // Duck typing test for GeoJSON
14127
+ function isGeoJSON(x) {
14128
+ switch (x?.type) {
14097
14129
  case "FeatureCollection":
14098
- return values.features;
14099
14130
  case "GeometryCollection":
14100
- return values.geometries;
14101
14131
  case "Feature":
14102
14132
  case "LineString":
14103
14133
  case "MultiLineString":
@@ -14106,9 +14136,10 @@
14106
14136
  case "Point":
14107
14137
  case "Polygon":
14108
14138
  case "Sphere":
14109
- return [values];
14139
+ return true;
14140
+ default:
14141
+ return false;
14110
14142
  }
14111
- return Array.from(values);
14112
14143
  }
14113
14144
 
14114
14145
  // An optimization of type.from(values, f): if the given values are already an
@@ -14490,11 +14521,13 @@
14490
14521
  function maybeNamed(things) {
14491
14522
  return isIterable(things) ? named(things) : things;
14492
14523
  }
14493
-
14494
- // TODO Accept other types of clips (paths, urls, x, y, other marks…)?
14495
- // https://github.com/observablehq/plot/issues/181
14496
14524
  function maybeClip(clip) {
14497
- if (clip === true) clip = "frame";else if (clip === false) clip = null;else if (clip != null) clip = keyword(clip, "clip", ["frame", "sphere"]);
14525
+ if (clip === true) clip = "frame";else if (clip === false) clip = null;else if (!isGeoJSON(clip) && clip != null) {
14526
+ clip = keyword(clip, "clip", ["frame", "sphere"]);
14527
+ if (clip === "sphere") clip = {
14528
+ type: "Sphere"
14529
+ };
14530
+ }
14498
14531
  return clip;
14499
14532
  }
14500
14533
 
@@ -14947,7 +14980,7 @@
14947
14980
  reduceIndex(I, X) {
14948
14981
  const n = 5;
14949
14982
  const groups = sort$1(rollup(I, V => V.length, i => X[i]), second);
14950
- const top = groups.slice(-5).reverse();
14983
+ const top = groups.slice(-n).reverse();
14951
14984
  if (top.length < groups.length) {
14952
14985
  const bottom = groups.slice(0, 1 - n);
14953
14986
  top[n - 1] = [`… ${bottom.length.toLocaleString("en-US")} more`, sum(bottom, second)];
@@ -15300,6 +15333,7 @@
15300
15333
  interpolate = registry.get(key) === color ? scheme == null && range !== undefined ? interpolateRgb : quantitativeScheme(scheme !== undefined ? scheme : type === "cyclical" ? "rainbow" : "turbo") : round ? interpolateRound : interpolateNumber,
15301
15334
  reverse: reverse$1
15302
15335
  }) {
15336
+ domain = maybeRepeat(domain);
15303
15337
  interval = maybeRangeInterval(interval, type);
15304
15338
  if (type === "cyclical" || type === "sequential") type = "linear"; // shorthand for color schemes
15305
15339
  if (typeof interpolate !== "function") interpolate = maybeInterpolator(interpolate); // named interpolator
@@ -15308,8 +15342,8 @@
15308
15342
  // If an explicit range is specified, and it has a different length than the
15309
15343
  // domain, then redistribute the range using a piecewise interpolator.
15310
15344
  if (range !== undefined) {
15311
- const n = (domain = arrayify(domain)).length;
15312
- const m = (range = arrayify(range)).length;
15345
+ const n = domain.length;
15346
+ const m = (range = maybeRepeat(range)).length;
15313
15347
  if (n !== m) {
15314
15348
  if (interpolate.length === 1) throw new Error("invalid piecewise interpolator"); // e.g., turbo
15315
15349
  interpolate = piecewise(interpolate, range);
@@ -15362,6 +15396,10 @@
15362
15396
  interval
15363
15397
  };
15364
15398
  }
15399
+ function maybeRepeat(values) {
15400
+ values = arrayify(values);
15401
+ return values.length >= 2 ? values : [values[0], values[0]];
15402
+ }
15365
15403
  function maybeNice(nice, type) {
15366
15404
  return nice === true ? undefined : typeof nice === "number" ? nice : maybeNiceInterval(nice, type);
15367
15405
  }
@@ -16273,10 +16311,11 @@
16273
16311
  if (kind === opacity || kind === length) return "linear";
16274
16312
  if (kind === symbol) return "ordinal";
16275
16313
 
16276
- // If the domain or range has more than two values, assume it’s ordinal. You
16277
- // can still use a “piecewise” (or “polylinear”) scale, but you must set the
16278
- // type explicitly.
16279
- if ((domain || range || []).length > 2) return asOrdinalType(kind);
16314
+ // If a domain or range is explicitly specified and doesn’t have two values,
16315
+ // assume it’s ordinal. You can still use a “piecewise” (or “polylinear”)
16316
+ // scale, but you must set the type explicitly.
16317
+ const n = (domain ?? range)?.length;
16318
+ if (n < 2 || n > 2) return asOrdinalType(kind);
16280
16319
 
16281
16320
  // Otherwise, infer the scale type from the data! Prefer the domain, if
16282
16321
  // present, over channels. (The domain and channels should be consistently
@@ -16504,14 +16543,20 @@
16504
16543
  marginTop,
16505
16544
  marginLeft
16506
16545
  }) {
16507
- return fx && fy ? ({
16508
- x,
16509
- y
16510
- }) => `translate(${fx(x) - marginLeft},${fy(y) - marginTop})` : fx ? ({
16546
+ const x = fx ? ({
16511
16547
  x
16512
- }) => `translate(${fx(x) - marginLeft},0)` : ({
16548
+ }) => fx(x) - marginLeft : () => 0;
16549
+ const y = fy ? ({
16513
16550
  y
16514
- }) => `translate(0,${fy(y) - marginTop})`;
16551
+ }) => fy(y) - marginTop : () => 0;
16552
+ return function (d) {
16553
+ if (this.tagName === "svg") {
16554
+ this.setAttribute("x", x(d));
16555
+ this.setAttribute("y", y(d));
16556
+ } else {
16557
+ this.setAttribute("transform", `translate(${x(d)},${y(d)})`);
16558
+ }
16559
+ };
16515
16560
  }
16516
16561
 
16517
16562
  // Returns an index that for each facet lists all the elements present in other
@@ -16962,6 +17007,23 @@
16962
17007
  return [x, y];
16963
17008
  }
16964
17009
 
17010
+ // If no projection is specified, default to a projection that passes points
17011
+ // through the x and y scales, if any.
17012
+ function xyProjection({
17013
+ x: X,
17014
+ y: Y
17015
+ }) {
17016
+ if (X || Y) {
17017
+ X ??= x => x;
17018
+ Y ??= y => y;
17019
+ return geoTransform({
17020
+ point(x, y) {
17021
+ this.stream.point(X(x), Y(y));
17022
+ }
17023
+ });
17024
+ }
17025
+ }
17026
+
16965
17027
  function createContext(options = {}) {
16966
17028
  const {
16967
17029
  document = typeof window !== "undefined" ? window.document : undefined,
@@ -17346,26 +17408,20 @@
17346
17408
  const {
17347
17409
  clip = context.clip
17348
17410
  } = mark;
17349
- switch (clip) {
17350
- case "frame":
17351
- {
17352
- // Wrap the G element with another (untransformed) G element, applying the
17353
- // clip to the parent G element so that the clip path is not affected by
17354
- // the mark’s transform. To simplify the adoption of this fix, mutate the
17355
- // passed-in selection.node to return the parent G element.
17356
- selection = create("svg:g", context).each(function () {
17357
- this.appendChild(selection.node());
17358
- selection.node = () => this; // Note: mutation!
17359
- });
17360
- clipUrl = getFrameClip(context, dimensions);
17361
- break;
17362
- }
17363
- case "sphere":
17364
- {
17365
- clipUrl = getProjectionClip(context);
17366
- break;
17367
- }
17411
+ if (clip === "frame") {
17412
+ // Wrap the G element with another (untransformed) G element, applying the
17413
+ // clip to the parent G element so that the clip path is not affected by
17414
+ // the mark’s transform. To simplify the adoption of this fix, mutate the
17415
+ // passed-in selection.node to return the parent G element.
17416
+ selection = create("svg:g", context).each(function () {
17417
+ this.appendChild(selection.node());
17418
+ selection.node = () => this; // Note: mutation!
17419
+ });
17420
+ clipUrl = getFrameClip(context, dimensions);
17421
+ } else if (clip) {
17422
+ clipUrl = getGeoClip(clip, context);
17368
17423
  }
17424
+
17369
17425
  // Here we’re careful to apply the ARIA attributes to the outer G element when
17370
17426
  // clipping is applied, and to apply the ARIA attributes before any other
17371
17427
  // attributes (for readability).
@@ -17397,15 +17453,21 @@
17397
17453
  } = dimensions;
17398
17454
  clipPath.append("rect").attr("x", marginLeft).attr("y", marginTop).attr("width", width - marginRight - marginLeft).attr("height", height - marginTop - marginBottom);
17399
17455
  });
17400
- const getProjectionClip = memoizeClip((clipPath, context) => {
17401
- const {
17402
- projection
17403
- } = context;
17404
- if (!projection) throw new Error(`the "sphere" clip option requires a projection`);
17405
- clipPath.append("path").attr("d", geoPath(projection)({
17406
- type: "Sphere"
17407
- }));
17408
- });
17456
+ const geoClipCache = new WeakMap();
17457
+ const sphere = {
17458
+ type: "Sphere"
17459
+ };
17460
+ function getGeoClip(geo, context) {
17461
+ let cache, url;
17462
+ if (!(cache = geoClipCache.get(context))) geoClipCache.set(context, cache = new WeakMap());
17463
+ if (geo.type === "Sphere") geo = sphere; // coalesce all spheres
17464
+ if (!(url = cache.get(geo))) {
17465
+ const id = getClipId();
17466
+ select(context.ownerSVGElement).append("clipPath").attr("id", id).append("path").attr("d", context.path()(geo));
17467
+ cache.set(geo, url = `url(#${id})`);
17468
+ }
17469
+ return url;
17470
+ }
17409
17471
 
17410
17472
  // Note: may mutate selection.node!
17411
17473
  function applyIndirectStyles(selection, mark, dimensions, context) {
@@ -17584,7 +17646,7 @@
17584
17646
  this.marginLeft = +marginLeft;
17585
17647
  this.clip = maybeClip(clip);
17586
17648
  this.tip = maybeTip(tip);
17587
- this.className = className ? maybeClassName(className) : null;
17649
+ this.className = string(className);
17588
17650
  // Super-faceting currently disallow position channels; in the future, we
17589
17651
  // could allow position to be specified in fx and fy in addition to (or
17590
17652
  // instead of) x and y.
@@ -19356,6 +19418,7 @@
19356
19418
  labelAnchor,
19357
19419
  labelArrow,
19358
19420
  labelOffset,
19421
+ ariaLabel = `${k}-axis`,
19359
19422
  ...options
19360
19423
  }) {
19361
19424
  tickSize = number(tickSize);
@@ -19371,6 +19434,7 @@
19371
19434
  tickPadding,
19372
19435
  tickRotate,
19373
19436
  x,
19437
+ ariaLabel,
19374
19438
  ...options
19375
19439
  }) : null, !isNoneish(fill) ? axisTextKy(k, anchor, data, {
19376
19440
  fill,
@@ -19387,6 +19451,7 @@
19387
19451
  marginRight,
19388
19452
  marginBottom,
19389
19453
  marginLeft,
19454
+ ariaLabel,
19390
19455
  ...options
19391
19456
  }) : null, !isNoneish(fill) && label !== null ? text([], labelOptions({
19392
19457
  fill,
@@ -19415,7 +19480,7 @@
19415
19480
  }
19416
19481
  this.dy = cla === "top" ? 3 - marginTop : cla === "bottom" ? marginBottom - 3 : 0;
19417
19482
  this.dx = anchor === "right" ? clo : -clo;
19418
- this.ariaLabel = `${k}-axis label`;
19483
+ this.ariaLabel = `${ariaLabel} label`;
19419
19484
  return {
19420
19485
  facets: [[0]],
19421
19486
  channels: {
@@ -19456,6 +19521,7 @@
19456
19521
  labelAnchor,
19457
19522
  labelArrow,
19458
19523
  labelOffset,
19524
+ ariaLabel = `${k}-axis`,
19459
19525
  ...options
19460
19526
  }) {
19461
19527
  tickSize = number(tickSize);
@@ -19471,6 +19537,7 @@
19471
19537
  tickPadding,
19472
19538
  tickRotate,
19473
19539
  y,
19540
+ ariaLabel,
19474
19541
  ...options
19475
19542
  }) : null, !isNoneish(fill) ? axisTextKx(k, anchor, data, {
19476
19543
  fill,
@@ -19487,6 +19554,7 @@
19487
19554
  marginRight,
19488
19555
  marginBottom,
19489
19556
  marginLeft,
19557
+ ariaLabel,
19490
19558
  ...options
19491
19559
  }) : null, !isNoneish(fill) && label !== null ? text([], labelOptions({
19492
19560
  fill,
@@ -19512,7 +19580,7 @@
19512
19580
  this.lineAnchor = anchor;
19513
19581
  this.dy = anchor === "top" ? -clo : clo;
19514
19582
  this.dx = cla === "right" ? marginRight - 3 : cla === "left" ? 3 - marginLeft : 0;
19515
- this.ariaLabel = `${k}-axis label`;
19583
+ this.ariaLabel = `${ariaLabel} label`;
19516
19584
  return {
19517
19585
  facets: [[0]],
19518
19586
  channels: {
@@ -19540,10 +19608,11 @@
19540
19608
  insetRight = inset,
19541
19609
  dx = 0,
19542
19610
  y = k === "y" ? undefined : null,
19611
+ ariaLabel,
19543
19612
  ...options
19544
19613
  }) {
19545
19614
  return axisMark(vectorY, k, data, {
19546
- ariaLabel: `${k}-axis tick`,
19615
+ ariaLabel: `${ariaLabel} tick`,
19547
19616
  ariaHidden: true
19548
19617
  }, {
19549
19618
  strokeWidth,
@@ -19571,10 +19640,11 @@
19571
19640
  insetBottom = inset,
19572
19641
  dy = 0,
19573
19642
  x = k === "x" ? undefined : null,
19643
+ ariaLabel,
19574
19644
  ...options
19575
19645
  }) {
19576
19646
  return axisMark(vectorX, k, data, {
19577
- ariaLabel: `${k}-axis tick`,
19647
+ ariaLabel: `${ariaLabel} tick`,
19578
19648
  ariaHidden: true
19579
19649
  }, {
19580
19650
  strokeWidth,
@@ -19604,11 +19674,12 @@
19604
19674
  insetLeft = inset,
19605
19675
  insetRight = inset,
19606
19676
  dx = 0,
19677
+ ariaLabel,
19607
19678
  y = k === "y" ? undefined : null,
19608
19679
  ...options
19609
19680
  }) {
19610
19681
  return axisMark(textY, k, data, {
19611
- ariaLabel: `${k}-axis tick label`
19682
+ ariaLabel: `${ariaLabel} tick label`
19612
19683
  }, {
19613
19684
  facetAnchor,
19614
19685
  frameAnchor,
@@ -19640,10 +19711,11 @@
19640
19711
  insetBottom = inset,
19641
19712
  dy = 0,
19642
19713
  x = k === "x" ? undefined : null,
19714
+ ariaLabel,
19643
19715
  ...options
19644
19716
  }) {
19645
19717
  return axisMark(textX, k, data, {
19646
- ariaLabel: `${k}-axis tick label`
19718
+ ariaLabel: `${ariaLabel} tick label`
19647
19719
  }, {
19648
19720
  facetAnchor,
19649
19721
  frameAnchor,
@@ -19681,11 +19753,13 @@
19681
19753
  x = null,
19682
19754
  x1 = anchor === "left" ? x : null,
19683
19755
  x2 = anchor === "right" ? x : null,
19756
+ ariaLabel = `${k}-grid`,
19757
+ ariaHidden = true,
19684
19758
  ...options
19685
19759
  }) {
19686
19760
  return axisMark(ruleY, k, data, {
19687
- ariaLabel: `${k}-grid`,
19688
- ariaHidden: true
19761
+ ariaLabel,
19762
+ ariaHidden
19689
19763
  }, {
19690
19764
  y,
19691
19765
  x1,
@@ -19698,11 +19772,13 @@
19698
19772
  y = null,
19699
19773
  y1 = anchor === "top" ? y : null,
19700
19774
  y2 = anchor === "bottom" ? y : null,
19775
+ ariaLabel = `${k}-grid`,
19776
+ ariaHidden = true,
19701
19777
  ...options
19702
19778
  }) {
19703
19779
  return axisMark(ruleX, k, data, {
19704
- ariaLabel: `${k}-grid`,
19705
- ariaHidden: true
19780
+ ariaLabel,
19781
+ ariaHidden
19706
19782
  }, {
19707
19783
  x,
19708
19784
  y1,
@@ -19892,7 +19968,7 @@
19892
19968
  // possible, or the default ISO format (2014-01-26). TODO We need a better way
19893
19969
  // to infer whether the ordinal scale is UTC or local time.
19894
19970
  function inferTickFormat(scale, data, ticks, tickFormat, anchor) {
19895
- return typeof tickFormat === "function" && !(scale.type === "log" && scale.tickFormat) ? tickFormat : tickFormat === undefined && data && isTemporal(data) ? inferTimeFormat(scale.type, data, anchor) ?? formatDefault : scale.tickFormat ? scale.tickFormat(typeof ticks === "number" ? ticks : null, tickFormat) : tickFormat === undefined ? formatDefault : typeof tickFormat === "string" ? (isTemporal(scale.domain()) ? utcFormat : format$1)(tickFormat) : constant(tickFormat);
19971
+ return typeof tickFormat === "function" && !(scale.type === "log" && scale.tickFormat) ? tickFormat : tickFormat === undefined && data && isTemporal(data) ? inferTimeFormat(scale.type, data, anchor) ?? formatDefault : scale.tickFormat ? scale.tickFormat(typeof ticks === "number" ? ticks : null, tickFormat) : typeof tickFormat === "string" && scale.domain().length > 0 ? (isTemporal(scale.domain()) ? utcFormat : format$1)(tickFormat) : tickFormat === undefined ? formatDefault : constant(tickFormat);
19896
19972
  }
19897
19973
  function inclusiveRange(interval, min, max) {
19898
19974
  return interval.range(min, interval.offset(interval.floor(max)));
@@ -20143,10 +20219,10 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
20143
20219
  return legends;
20144
20220
  }
20145
20221
 
20146
- function maybeIdentityY(options = {}) {
20222
+ function maybeIdentityY(options = {}, k = "y") {
20147
20223
  return hasY(options) ? options : {
20148
20224
  ...options,
20149
- y: identity$1
20225
+ [k]: identity$1
20150
20226
  };
20151
20227
  }
20152
20228
 
@@ -21373,6 +21449,11 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
21373
21449
  context.className = className;
21374
21450
  context.projection = createProjection(options, subdimensions);
21375
21451
 
21452
+ // A path generator for marks that want to draw GeoJSON.
21453
+ context.path = function () {
21454
+ return geoPath(this.projection ?? xyProjection(scales));
21455
+ };
21456
+
21376
21457
  // Allows e.g. the axis mark to determine faceting lazily.
21377
21458
  context.filterFacets = (data, channels) => {
21378
21459
  return facetFilter(facets, {
@@ -21398,7 +21479,7 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
21398
21479
  context.dispatchValue = value => {
21399
21480
  if (figure.value === value) return;
21400
21481
  figure.value = value;
21401
- figure.dispatchEvent(new Event("input", {
21482
+ figure.dispatchEvent(new context.document.defaultView.Event("input", {
21402
21483
  bubbles: true
21403
21484
  }));
21404
21485
  };
@@ -21544,7 +21625,7 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
21544
21625
  }
21545
21626
  }
21546
21627
  }
21547
- g?.selectChildren().attr("transform", facetTranslate);
21628
+ g?.selectChildren().each(facetTranslate);
21548
21629
  }
21549
21630
  }
21550
21631
 
@@ -22704,11 +22785,10 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
22704
22785
  const {
22705
22786
  curve
22706
22787
  } = this;
22707
- return create("svg:g", context).call(applyIndirectStyles, this, dimensions, context).call(applyTransform, this, scales).call(g => g.selectAll().data(groupIndex(index, [X, Y], this, channels)).enter().append("path").call(applyDirectStyles, this).call(applyGroupedChannelStyles, this, channels).call(applyGroupedMarkers, this, channels, context).attr("d", curve === curveAuto && context.projection ? sphereLine(context.projection, X, Y) : shapeLine().curve(curve).defined(i => i >= 0).x(i => X[i]).y(i => Y[i]))).node();
22788
+ return create("svg:g", context).call(applyIndirectStyles, this, dimensions, context).call(applyTransform, this, scales).call(g => g.selectAll().data(groupIndex(index, [X, Y], this, channels)).enter().append("path").call(applyDirectStyles, this).call(applyGroupedChannelStyles, this, channels).call(applyGroupedMarkers, this, channels, context).attr("d", curve === curveAuto && context.projection ? sphereLine(context.path(), X, Y) : shapeLine().curve(curve).defined(i => i >= 0).x(i => X[i]).y(i => Y[i]))).node();
22708
22789
  }
22709
22790
  }
22710
- function sphereLine(projection, X, Y) {
22711
- const path = geoPath(projection);
22791
+ function sphereLine(path, X, Y) {
22712
22792
  X = coerceNumbers(X);
22713
22793
  Y = coerceNumbers(Y);
22714
22794
  return I => {
@@ -22774,7 +22854,7 @@ ${extraStyle}`)).style("margin-left", marginLeft ? `${+marginLeft}px` : null).st
22774
22854
  };
22775
22855
  }
22776
22856
 
22777
- var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  var distributions$1 = {exports: {}};

  var distributions = distributions$1.exports;
  (function (module) {

    // A number of log probability density functions (PDF). Naming and parameterization
    // should match R's, except for that all functions reside in an ld object (
    // as in "log density"), so to get a normal log density you would write
    // ld.norm(...).
    // Most of the code below is directly taken from the great Jstat project
    // (https://github.com/jstat/) which includes PDF for many common probability
    // distributions. What I have done is only to convert these to log PDFs.

    /*
    Original work Copyright (c) 2013 jStat
    Modified work Copyright (c) 2015 Rasmus Bååth 
    	Permission is hereby granted, free of charge, to any person obtaining a copy
    of this software and associated documentation files (the "Software"), to deal
    in the Software without restriction, including without limitation the rights
    to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    copies of the Software, and to permit persons to whom the Software is
    furnished to do so, subject to the following conditions:
    	The above copyright notice and this permission notice shall be included in
    all copies or substantial portions of the Software.
    	THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    THE SOFTWARE.
    	*/

    // This boiler plate code here is taken from:
    // https://github.com/umdjs/umd/blob/master/templates/returnExports.js
    // It should make shure that module can be imported both in the browser,
    // Node, and by using the Asynchronous Module Definition standard.
    // If this module is loaded in the browser it will created the global
    // object ld .
    (function (root, factory) {
      if (module.exports) {
        // Node. Does not work with strict CommonJS, but
        // only CommonJS-like environments that support module.exports,
        // like Node.
        module.exports = factory();
      } else {
        // Browser globals (root is window)
        root.ld = factory();
      }
    })(distributions, function () {
      // Object to hold the functions to be exported.
      var ld = {};

      ////////// Helper functions //////////
      //////////////////////////////////////

      var lgamma = function (x) {
        var j = 0;
        var cof = [76.18009172947146, -86.50532032941678, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -5395239384953e-18];
        var ser = 1.000000000190015;
        var xx, y, tmp;
        tmp = (y = xx = x) + 5.5;
        tmp -= (xx + 0.5) * log(tmp);
        for (; j < 6; j++) ser += cof[j] / ++y;
        return log(2.5066282746310005 * ser / xx) - tmp;
      };
      ld.lgamma = lgamma;
      var lfactorial = function (n) {
        return n < 0 ? NaN : lgamma(n + 1);
      };
      ld.lfactorial = lfactorial;
      var lchoose = function (n, k) {
        return lfactorial(n) - lfactorial(k) - lfactorial(n - k);
      };
      ld.lchoose = lchoose;
      var lbeta = function (a, b) {
        return lgamma(a) + lgamma(b) - lgamma(a + b);
      };
      ld.lbeta = lbeta;
      var log = Math.log;
      var exp = Math.exp;
      var abs = Math.abs;
      var pow = Math.pow;
      var sqrt = Math.sqrt;
      var pi = Math.PI;

      ////////// Continous distributions //////////
      /////////////////////////////////////////////

      ld.beta = function (x, shape1, shape2) {
        if (x > 1 || x < 0) {
          return -Infinity;
        }
        if (shape1 === 1 && shape2 === 1) {
          return 0;
        } else {
          return (shape1 - 1) * log(x) + (shape2 - 1) * log(1 - x) - lbeta(shape1, shape2);
        }
      };
      ld.cauchy = function (x, location, scale) {
        return log(scale) - log(pow(x - location, 2) + pow(scale, 2)) - log(pi);
      };
      ld.norm = function (x, mean, sd) {
        return -0.5 * log(2 * pi) - log(sd) - pow(x - mean, 2) / (2 * sd * sd);
      };

      // A bivariate Normal distribution parameterized by arrays of two means and SDs, and 
      // the correlation.
      ld.bivarnorm = function (x, mean, sd, corr) {
        var z = pow(x[0] - mean[0], 2) / pow(sd[0], 2) + pow(x[1] - mean[1], 2) / pow(sd[1], 2) - 2 * corr * (x[0] - mean[0]) * (x[1] - mean[1]) / (sd[0] * sd[1]);
        var normalizing_factor = -(log(2) + log(pi) + log(sd[0]) + log(sd[1]) + 0.5 * log(1 - pow(corr, 2)));
        var bivar_log_dens = normalizing_factor - z / (2 * (1 - pow(corr, 2)));
        return bivar_log_dens;
      };
      ld.laplace = function (x, location, scale) {
        return -abs(x - location) / scale - log(2 * scale);
      };
      ld.dexp = ld.laplace;
      ld.gamma = function (x, shape, rate) {
        var scale = 1 / rate;
        if (x < 0) {
          return -Infinity;
        }
        if (x === 0 && shape === 1) {
          return -log(scale);
        } else {
          return (shape - 1) * log(x) - x / scale - lgamma(shape) - shape * log(scale);
        }
      };
      ld.invgamma = function (x, shape, scale) {
        if (x <= 0) {
          return -Infinity;
        }
        return -(shape + 1) * log(x) - scale / x - lgamma(shape) + shape * log(scale);
      };
      ld.lnorm = function (x, meanlog, sdlog) {
        if (x <= 0) {
          return -Infinity;
        }
        return -log(x) - 0.5 * log(2 * pi) - log(sdlog) - pow(log(x) - meanlog, 2) / (2 * sdlog * sdlog);
      };
      ld.pareto = function (x, scale, shape) {
        if (x < scale) {
          return -Infinity;
        }
        return log(shape) + shape * log(scale) - (shape + 1) * log(x);
      };
      ld.t = function (x, location, scale, df) {
        df = df > 1e100 ? 1e100 : df;
        return lgamma((df + 1) / 2) - lgamma(df / 2) - log(sqrt(pi * df) * scale) + log(pow(1 + 1 / df * pow((x - location) / scale, 2), -(df + 1) / 2));
      };

      // This is a direct javascript translation of the R code used to evaluate
      // the log density of a weibull distribution: 
      // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dweibull.c
      ld.weibull = function (x, shape, scale) {
        if (x < 0) return -Infinity;
        if (x === 0 && shape < 1) return Infinity;
        var tmp1 = pow(x / scale, shape - 1);
        var tmp2 = tmp1 * (x / scale);
        return -tmp2 + log(shape * tmp1 / scale);
      };

      // This is a direct javascript translation of the R code used to evaluate
      // the log density of a logistic distribution: 
      // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dlogis.c
      ld.logis = function (x, location, scale) {
        x = abs((x - location) / scale);
        var e = exp(-x);
        var f = 1.0 + e;
        return -(x + log(scale * f * f));
      };
      ld.dirichlet = function (x, alpha) {
        var sum_alpha = 0;
        var sum_lgamma_alpha = 0;
        var sum_alpha_sub_1_log_x = 0;
        var n = alpha.length;
        for (var i = 0; i < n; i++) {
          sum_alpha += alpha[i];
          sum_lgamma_alpha += lgamma(alpha[i]);
          sum_alpha_sub_1_log_x += (alpha[i] - 1) * log(x[i]);
        }
        return lgamma(sum_alpha) - sum_lgamma_alpha + sum_alpha_sub_1_log_x;
      };
      ld.exp = function (x, rate) {
        return x < 0 ? -Infinity : log(rate) - rate * x;
      };
      ld.unif = function (x, min, max) {
        return x < min || x > max ? -Infinity : log(1 / (max - min));
      };

      ////////// Discrete distributions //////////
      ////////////////////////////////////////////

      ld.bern = function (x, prob) {
        return !(x === 0 || x === 1) ? -Infinity : log(x * prob + (1 - x) * (1 - prob));
      };
      ld.cat = function (x, probs) {
        if (x < 1 || x > probs.length) {
          return -Infinity;
        } else {
          return log(probs[x - 1]);
        }
      };
      ld.binom = function (x, size, prob) {
        if (x > size || x < 0) {
          return -Infinity;
        }
        if (prob === 0 || prob === 1) {
          return size * prob === x ? 0 : -Infinity;
        }
        return lchoose(size, x) + x * log(prob) + (size - x) * log(1 - prob);
      };
      ld.nbinom = function (x, size, prob) {
        if (x < 0) {
          return -Infinity;
        }
        return lchoose(x + size - 1, size - 1) + x * log(1 - prob) + size * log(prob);
      };
      ld.hyper = function (x, m, n, k) {
        if (x < 0 || x > k) {
          return -Infinity;
        } else {
          return lchoose(m, x) + lchoose(n, k - x) - lchoose(m + n, k);
        }
      };
      ld.pois = function (x, lambda) {
        return x < 0 ? -Infinity : log(lambda) * x - lambda - lfactorial(x);
      };
      return ld;
    });
  })(distributions$1);
  var distributionsExports = distributions$1.exports;

  var mcmc$1 = {exports: {}};

  var mcmc = mcmc$1.exports;
  (function (module) {

    // This boiler plate code here is taken from:
    // https://github.com/umdjs/umd/blob/master/templates/returnExports.js
    // It should make shure that module can be imported both in the browser,
    // Node, and by using the Asynchronous Module Definition standard.
    // If this module is loaded in the browser it will created the global
    // object mcmc .
    (function (root, factory) {
      if (module.exports) {
        // Node. Does not work with strict CommonJS, but
        // only CommonJS-like environments that support module.exports,
        // like Node.
        module.exports = factory();
      } else {
        // Browser globals (root is window)
        root.mcmc = factory();
      }
    })(mcmc, function () {
      /// The actual module code starts here ///
      //////////////////////////////////////////  

      ////////// Helper Functions //////////
      //////////////////////////////////////

      /** Returns a random real number between min and max */
      var runif = function (min, max) {
        return Math.random() * (max - min) + min;
      };

      /** Returns a random integer between min and max */
      var runif_discrete = function (min, max) {
        return Math.floor(Math.random() * (max - min + 1)) + min;
      };

      /** Returns a random real number from a normal distribbution defined
       *  by mean and sd. 
       *  Adapted from https://github.com/jstat/jstat/blob/master/src/special.js */
      var rnorm = function (mean, sd) {
        var u, v, x, y, q;
        do {
          u = Math.random();
          v = 1.7156 * (Math.random() - 0.5);
          x = u - 0.449871;
          y = Math.abs(v) + 0.386595;
          q = x * x + y * (0.19600 * y - 0.25472 * x);
        } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u));
        return v / u * sd + mean;
      };

      /** Returns a deep clone of src, sort of... It only copies a limited
       * number of types and, for example, function are not copied. 
       * From http://davidwalsh.name/javascript-clone
       */
      var deep_clone = function (src) {
        function mixin(dest, source, copyFunc) {
          var name,
            s,
            empty = {};
          for (name in source) {
            // the (!(name in empty) || empty[name] !== s) condition avoids copying properties in "source"
            // inherited from Object.prototype.	 For example, if dest has a custom toString() method,
            // don't overwrite it with the toString() method that source inherited from Object.prototype
            s = source[name];
            if (!(name in dest) || dest[name] !== s && (!(name in empty) || empty[name] !== s)) {
              dest[name] = copyFunc ? copyFunc(s) : s;
            }
          }
          return dest;
        }
        if (!src || typeof src != "object" || Object.prototype.toString.call(src) === "[object Function]") {
          // null, undefined, any non-object, or function
          return src; // anything
        }
        if (src.nodeType && "cloneNode" in src) {
          // DOM Node
          return src.cloneNode(true); // Node
        }
        if (src instanceof Date) {
          // Date
          return new Date(src.getTime()); // Date
        }
        if (src instanceof RegExp) {
          // RegExp
          return new RegExp(src); // RegExp
        }
        var r, i, l;
        if (src instanceof Array) {
          // array
          r = [];
          for (i = 0, l = src.length; i < l; ++i) {
            if (i in src) {
              r.push(deep_clone(src[i]));
            }
          }
        } else {
          // generic objects
          r = src.constructor ? new src.constructor() : {};
        }
        return mixin(r, src, deep_clone);
      };

      /** Specialized clone function that only clones scalars and nested arrays where
       * each array either consists of all arrays or all numbers. This function
       * is meant as a fast way of cloning parameter draws within the mcmc sampling
       * loop.
       */
      var clone_param_draw = function (x) {
        if (Array.isArray(x)) {
          if (Array.isArray(x[0])) {
            // x is an array of arrays so we need to clone it recursively
            var x_copy = [];
            for (var i = 0, length = x.length; i < length; i++) {
              x_copy.push(clone_param_draw(x[i]));
            }
            return x_copy;
          } else {
            // We'll assume x is a arrays of scalars
            return x.slice(0);
          }
        } else {
          // We'll assume x is a scalar
          return x;
        }
      };

      /** Returns true if object is a number.
       */
      var is_number = function (object) {
        return typeof object == "number" || typeof object == "object" && object.constructor === Number;
      };

      /**
       * Creates and initializes a (possibly multidimensional/nested) array.
       * @param dim - An array giving the dimension of the array. For example,
       *   [5] would yield a 5 element array, and [3,3] would yield a 3 by 3 matrix.
       * @param init - A value or a function used to fill in the each element in
       *   the array. If it is a function it should take no arguments, it will be 
       *   evaluated once for each element, and it's return value will be used to
       *   fill in each element.
       * @example 
       * // The following would return [[1,1],[1,1],[1,1]]
       * create_array([2,3], 1)
       */
      var create_array = function (dim, init) {
        var arr = new Array(dim[0]);
        var i;
        if (dim.length == 1) {
          // Fill it up with init
          if (typeof init === "function") {
            for (i = 0; i < dim[0]; i++) {
              arr[i] = init();
            }
          } else {
            for (i = 0; i < dim[0]; i++) {
              arr[i] = init;
            }
          }
        } else if (dim.length > 1) {
          for (i = 0; i < dim[0]; i++) {
            arr[i] = create_array(dim.slice(1), init);
          }
        } else {
          throw "create_array can't create a dimensionless array";
        }
        return arr;
      };

      /**
       * Return the dimensions of a possibly nested array as an array. For 
       * example, array_dim( [[1, 2], [1, 2]] ) should return [2, 2]
       * Assumes that all arrays inside another array are of the same length.
       * @example
       * // Should return [4, 2, 1]
       * array_dim(create_array([4, 2, 1], 0))
       */
      var array_dim = function (a) {
        if (Array.isArray(a[0])) {
          return [a.length].concat(array_dim(a[0]));
        } else {
          return [a.length];
        }
      };

      /**
       * Checks if two arrays are equal in the sense that they contain the same elements
       * as judged by the "==" operator. Returns true or false.
       * Adapted from http://stackoverflow.com/a/14853974/1001848
       */
      var array_equal = function (a1, a2) {
        if (a1.length != a2.length) return false;
        for (var i = 0; i < a1.length; i++) {
          // Check if we have nested arrays
          if (Array.isArray(a1[i]) && Array.isArray(a2[i])) {
            // recurse into the nested arrays
            if (!array_equal(a1[i], a2[i])) return false;
          } else if (a1[i] != a2[i]) {
            // Warning - two different object instances will never be equal: {x:20} != {x:20}
            return false;
          }
        }
        return true;
      };

      /**
       * Traverses a possibly nested array a and applies fun to all "leaf nodes", 
       * that is, values that are not arrays. Returns an array of the same size as
       * a.
       */
      var nested_array_apply = function (a, fun) {
        if (Array.isArray(a)) {
          var result = new Array(a.length);
          for (var i = 0; i < a.length; i++) {
            result[i] = nested_array_apply(a[i], fun);
          }
          return result;
        } else {
          return fun(a);
        }
      };

      /** Randomizing the array element order in-place. Using Durstenfeld
       * shuffle algorithm. Adapted from here: 
       * http://stackoverflow.com/a/12646864/1001848
       */
      function shuffle_array(array) {
        for (var i = array.length - 1; i > 0; i--) {
          var j = Math.floor(Math.random() * (i + 1));
          var temp = array[i];
          array[i] = array[j];
          array[j] = temp;
        }
        return array;
      }

      /**
       * Does the same thing as nested_array_apply, that is, traverses a possibly
       * nested array a and applies fun to all "leaf nodes" and returns an array 
       * of the same size as a. The difference is that nested_array_random_apply
       * branches randomly.
       */
      var nested_array_random_apply = function (a, fun) {
        if (Array.isArray(a)) {
          var len = a.length;
          var i;
          var array_is = [];
          for (i = 0; i < len; i++) {
            array_is[i] = i;
          }
          shuffle_array(array_is);
          var result = [];
          for (i = 0; i < len; i++) {
            var array_i = array_is[i];
            result[array_i] = nested_array_apply(a[array_i], fun);
          }
          return result;
        } else {
          return fun(a);
        }
      };

      /**
       * Allows a pretty way of setting default options where the defults can be
       * overridden by an options object.
       *  @param option_name - the name of the option as a string
       *  @param my_options - an option object that could have option_name 
       *    as a member.
       * @param defaul_value - defult value that is returned if option_name 
       *   is not defined in my_options.
       * @example
       * var my_options = {pi: 3.14159}
       * var pi = get_option("pi", my_options, 3.14)
       */
      // Pretty way of setting default options where the defaults can be overridden
      // by an options object. For example:
      // var pi = get_option("pi", my_options, 3.14)
      var get_option = function (option_name, options, defaul_value) {
        options = options || {};
        return options.hasOwnProperty(option_name) && options[option_name] !== undefined && options[option_name] !== null ? options[option_name] : defaul_value;
      };

      /** Version of get_option where the option should be a one or multi-dimensional
       * array and where the default can be overridden either by a scalar or by an array.
       * If it's a scalar the that scalar is used to initialize an array with 
       * dim dimensions.
       * 
       */
      var get_multidim_option = function (option_name, options, dim, defaul_value) {
        var value = get_option(option_name, options, defaul_value);
        if (!Array.isArray(value)) {
          value = create_array(dim, value);
        }
        if (!array_equal(array_dim(value), dim)) {
          throw "The option " + option_name + " is of dimension [" + array_dim(value) + "] but should be [" + dim + "].";
        }
        return value;
      };

      ////////// Functions for handling parameter objects //////////
      //////////////////////////////////////////////////////////////

      /**
       * Returns a fixed (same every time) number that could be used to initialize
       * a parameter of a certain type, possibly with lower and upper bounds.
       * The possile types are "real", "int", and "binary".
       */
      var param_init_fixed = function (type, lower, upper) {
        if (lower > upper) {
          throw "Can not initialize parameter where lower bound > upper bound";
        }
        if (type === "real") {
          if (lower === -Infinity && upper === Infinity) {
            return 0.5;
          } else if (lower === -Infinity) {
            return upper - 0.5;
          } else if (upper === Infinity) {
            return lower + 0.5;
          } else if (lower <= upper) {
            return (lower + upper) / 2;
          }
        } else if (type === "int") {
          if (lower === -Infinity && upper === Infinity) {
            return 1;
          } else if (lower === -Infinity) {
            return upper - 1;
          } else if (upper === Infinity) {
            return lower + 1;
          } else if (lower <= upper) {
            return Math.round((lower + upper) / 2);
          }
        } else if (type === "binary") {
          return 1;
        }
        throw "Could not initialize parameter of type " + type + "[" + lower + ", " + upper + "]";
      };

      /**
       * Completes params_to_complete, an object containing parameter descriptions, 
       * and initializes non-initialized parameters. This modified version of
       * params_to_complete is returned as a deep copy and not modified in place.
       * Initialization is done by supplying a param_init function with signature
       * function(type, lower, upper) that should return a single number 
       * (like param_init_fixed, for example).
       * @example
       * var params = { "mu": {"type": "real"} }
       * params = complete_params(params);
       * // params should now be:
       * //  {"mu": { "type": "real", "dim": [1], "upper": Infinity,
       * //           "lower": -Infinity, "init": 0.5 }}
       */
      var complete_params = function (params_to_complete, param_init) {
        var params = deep_clone(params_to_complete);
        for (var param_name in params) {
          if (!params.hasOwnProperty(param_name)) continue;
          var param = params[param_name];
          if (!param.hasOwnProperty("type")) {
            param.type = "real";
          }
          if (!param.hasOwnProperty("dim")) {
            param.dim = [1];
          }
          if (is_number(param.dim)) {
            param.dim = [param.dim];
          }
          if (param.type == "binary") {
            param.upper = 1;
            param.lower = 0;
          }
          if (!param.hasOwnProperty("upper")) {
            param.upper = Infinity;
          }
          if (!param.hasOwnProperty("lower")) {
            param.lower = -Infinity;
          }
          if (param.hasOwnProperty("init")) {
            // If this is just a number or a nested array we leave it alone, but if...
            if (array_equal(param.dim, [1]) && typeof param.init === "function") {
              // param.init is a function, use that to initialize the parameter.
              param.init = param.init();
            } else if (!array_equal(param.dim, [1]) && !Array.isArray(param.init)) {
              // We have a multidimensional parameter where the param.init exist but
              // is not an array. Then assume it is a number or a function and use
              // it to initialize the parameter.
              param.init = create_array(param.dim, param.init);
            }
          } else {
            // We use the default initialization function.
            if (array_equal(param.dim, [1])) {
              param.init = param_init(param.type, param.lower, param.upper);
            } else {
              param.init = create_array(param.dim, function () {
                return param_init(param.type, param.lower, param.upper);
              });
            }
          }
        }
        return params;
      };

      ////////// Stepper Functions ///////////
      ////////////////////////////////////////

      /**
       * @interface
       * A Stepper is an object responsible for pushing around one
       * or more parameter values in a state according to the distribution
       * defined by the log posterior. This defines the Stepper "interface",
       * where "interface" means that Stepper defines a class that is never
       * meant to be instantiated, but just to be subclassed by specialized
       * stepper functions.
       * @interface
       * @param params - An object with parameter definitions, for example:
       *   {"mu": { "type": "real", "dim": [1], "upper": Infinity, 
       *   "lower": -Infinity, "init": 0.5 }}
       *   The parameter definitions are expected to be "complete", that is,
       *   specifying all relevant attributes such as dim, lower and upper.
       * @param state - an object containing the state of all parameters in params
       *   (and possibly more). The parameter names are given as keys and the states
       *   as scalars or, possibly nested, arrays. For example:
       *   {mu: 10, sigma: 5, beta: [1, 2.5]}
       * @param log_post - A function *taking no parameters* that returns the
       *   log density that depends on the state. That is, the value of log_post
       *   should change if the the values in state are changed.
      
       */
      var Stepper = function (params, state, log_post) {
        this.params = params;
        this.state = state;
        this.log_post = log_post;
      };

      /**
       * Takes a step in the parameter space. Should return the new state,
       * but is mainly called for it's side effect of making a change in the
       * state object.
       */
      Stepper.prototype.step = function () {
        throw "Every Stepper need to implement step()";
      };

      /**
       * If implemented, makes the stepper adapt while stepping.
       */
      Stepper.prototype.start_adaptation = function () {
        // Optional, some steppers might not be adaptive. */ 
      };

      /**
       * If implemented, makes the stepper cease adapting while stepping.
       */
      Stepper.prototype.stop_adaptation = function () {
        // Optional, some steppers might not be adaptive. */ 
      };

      /**
       * Returns an object containg info regarding the stepper.
       */
      Stepper.prototype.info = function () {
        // Returns an object with info about the state of the stepper.
        return {};
      };

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements the metropolis step in
       * the Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
       * by Roberts and Rosenthal (2008).
       * @param params - An object with a single parameter definition.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
       * @param generate_proposal - a function returning a proposal (as a number)
       * with signature function(param_state, log_scale) where param_state is a
       * number and log_scale defines the scale of the proposal somehow.
      */
      var OnedimMetropolisStepper = function (params, state, log_post, options, generate_proposal) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length != 1) {
          throw "OnedimMetropolisStepper can only handle one parameter.";
        }
        this.param_name = param_names[0];
        var param = this.params[this.param_name];
        if (!array_equal(param.dim, [1])) {
          throw "OnedimMetropolisStepper can only handle one one-dimensional parameter.";
        }
        this.lower = param.lower;
        this.upper = param.upper;
        this.prop_log_scale = get_option("prop_log_scale", options, 0);
        this.batch_size = get_option("batch_size", options, 50);
        this.max_adaptation = get_option("max_adaptation", options, 0.33);
        this.initial_adaptation = get_option("initial_adaptation", options, 1.0);
        this.target_accept_rate = get_option("target_accept_rate", options, 0.44);
        this.is_adapting = get_option("is_adapting", options, true);
        this.generate_proposal = generate_proposal;
        this.acceptance_count = 0;
        this.batch_count = 0;
        this.iterations_since_adaption = 0;
      };
      OnedimMetropolisStepper.prototype = Object.create(Stepper.prototype);
      OnedimMetropolisStepper.prototype.constructor = OnedimMetropolisStepper;
      OnedimMetropolisStepper.prototype.step = function () {
        var param_state = this.state[this.param_name];
        var param_proposal = this.generate_proposal(param_state, this.prop_log_scale);
        if (param_proposal < this.lower || param_proposal > this.upper) ; else {
          // make a Metropolis step
          var curr_log_dens = this.log_post();
          this.state[this.param_name] = param_proposal;
          var prop_log_dens = this.log_post();
          var accept_prob = Math.exp(prop_log_dens - curr_log_dens);
          if (accept_prob > Math.random()) {
            // We do nothing as the state of param has already been changed to the proposal
            if (this.is_adapting) this.acceptance_count++;
          } else {
            // revert state back to the old state of param
            this.state[this.param_name] = param_state;
          }
        }
        if (this.is_adapting) {
          this.iterations_since_adaption++;
          if (this.iterations_since_adaption >= this.batch_size) {
            // then adapt
            this.batch_count++;
            var log_sd_adjustment = Math.min(this.max_adaptation, this.initial_adaptation / Math.sqrt(this.batch_count));
            if (this.acceptance_count / this.batch_size > this.target_accept_rate) {
              this.prop_log_scale += log_sd_adjustment;
            } else {
              this.prop_log_scale -= log_sd_adjustment;
            }
            this.acceptance_count = 0;
            this.iterations_since_adaption = 0;
          }
        }
        return this.state[this.param_name];
      };
      OnedimMetropolisStepper.prototype.start_adaptation = function () {
        this.is_adapting = true;
      };
      OnedimMetropolisStepper.prototype.stop_adaptation = function () {
        this.is_adapting = false;
      };
      OnedimMetropolisStepper.prototype.info = function () {
        return {
          prop_log_scale: this.prop_log_scale,
          is_adapting: this.is_adapting,
          acceptance_count: this.acceptance_count,
          iterations_since_adaption: this.iterations_since_adaption,
          batch_count: this.batch_count
        };
      };

      /**
       * Function returning a Normal proposal.
       */
      var normal_proposal = function (param_state, prop_log_scale) {
        return rnorm(param_state, Math.exp(prop_log_scale));
      };

      /**
       * @class
       * @augments {OnedimMetropolisStepper}
       * A "subclass" of OnedimMetropolisStepper making continous Normal proposals.
       */
      var RealMetropolisStepper = function (params, state, log_post, options) {
        OnedimMetropolisStepper.call(this, params, state, log_post, options, normal_proposal);
      };
      RealMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype);
      RealMetropolisStepper.prototype.constructor = RealMetropolisStepper;

      /**
       * Function returning a discretized Normal proposal.
       */
      var discrete_normal_proposal = function (param_state, prop_log_scale) {
        return Math.round(rnorm(param_state, Math.exp(prop_log_scale)));
      };

      /**
      * @class
      * @augments {OnedimMetropolisStepper}
      * A "subclass" of OnedimMetropolisStepper making discretized Normal proposals.
      */
      var IntMetropolisStepper = function (params, state, log_post, options) {
        OnedimMetropolisStepper.call(this, params, state, log_post, options, discrete_normal_proposal);
      };
      IntMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype);
      IntMetropolisStepper.prototype.constructor = IntMetropolisStepper;

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements the metropolis step in
       * the Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
       * by Roberts and Rosenthal (2008) for possibly multidimensional arrays. That
       * is, instead of just taking a step for a one-dimensional parameter like 
       * OnedimMetropolisStepper, this Stepper is responsible for taking steps 
       * for a multidimensional array. It's still pretty dumb and just takes
       * one-dimensional steps for each parameter component, though.
       * @param params - An object with a single parameter definition for a 
       *   multidimensional parameter.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
       * @param SubStepper - a constructor for the type of one dimensional Stepper to apply on
       *   all the components of the multidimensional parameter.
      */
      var MultidimComponentMetropolisStepper = function (params, state, log_post, options, SubStepper) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length != 1) {
          throw "MultidimComponentMetropolisStepper can't handle more than one parameter.";
        }
        this.param_name = param_names[0];
        var param = this.params[this.param_name];
        this.lower = param.lower;
        this.upper = param.upper;
        this.dim = param.dim;
        this.prop_log_scale = get_multidim_option("prop_log_scale", options, this.dim, 0);
        this.batch_size = get_multidim_option("batch_size", options, this.dim, 50);
        this.max_adaptation = get_multidim_option("max_adaptation", options, this.dim, 0.33);
        this.initial_adaptation = get_multidim_option("initial_adaptation", options, this.dim, 1.0);
        this.target_accept_rate = get_multidim_option("target_accept_rate", options, this.dim, 0.44);
        this.is_adapting = get_multidim_option("is_adapting", options, this.dim, true);

        // This hack below is a recursive function that creates an array of 
        // one dimensional steppers according to dim.
        var create_substeppers = function (dim, substate, log_post, prop_log_scale, batch_size, max_adaptation, initial_adaptation, target_accept_rate, is_adapting) {
          var substeppers = [];
          if (dim.length === 1) {
            for (var i = 0; i < dim[0]; i++) {
              var suboptions = {
                prop_log_scale: prop_log_scale[i],
                batch_size: batch_size[i],
                max_adaptation: max_adaptation[i],
                initial_adaptation: initial_adaptation[i],
                target_accept_rate: target_accept_rate[i],
                is_adapting: is_adapting[i]
              };
              var subparam = {};
              subparam[i] = deep_clone(param);
              subparam[i].dim = [1]; // As this should now be a one-dim parameter
              delete subparam[i].init; // As it sould not be needed
              substeppers[i] = new SubStepper(subparam, substate, log_post, suboptions);
            }
          } else {
            for (var i = 0; i < dim[0]; i++) {
              substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post, prop_log_scale[i], batch_size[i], max_adaptation[i], initial_adaptation[i], target_accept_rate[i], is_adapting[i]);
            }
          }
          return substeppers;
        };
        this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post, this.prop_log_scale, this.batch_size, this.max_adaptation, this.initial_adaptation, this.target_accept_rate, this.is_adapting);
      };
      MultidimComponentMetropolisStepper.prototype = Object.create(Stepper.prototype);
      MultidimComponentMetropolisStepper.prototype.constructor = MultidimComponentMetropolisStepper;
      MultidimComponentMetropolisStepper.prototype.step = function () {
        // Go through the substeppers in a random order and call step() on them.
        return nested_array_random_apply(this.substeppers, function (substepper) {
          return substepper.step();
        });
      };
      MultidimComponentMetropolisStepper.prototype.start_adaptation = function () {
        nested_array_apply(this.substeppers, function (substepper) {
          substepper.start_adaptation();
        });
      };
      MultidimComponentMetropolisStepper.prototype.stop_adaptation = function () {
        nested_array_apply(this.substeppers, function (substepper) {
          substepper.stop_adaptation();
        });
      };
      MultidimComponentMetropolisStepper.prototype.info = function () {
        return nested_array_apply(this.substeppers, function (substepper) {
          return substepper.info();
        });
      };

      /**
       * @class
       * @augments {MultidimComponentMetropolisStepper}
       * A "subclass" of MultidimComponentMetropolisStepper making continous Normal proposals.
       */
      var MultiRealComponentMetropolisStepper = function (params, state, log_post, options) {
        MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, RealMetropolisStepper);
      };
      MultiRealComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype);
      MultiRealComponentMetropolisStepper.prototype.constructor = MultiRealComponentMetropolisStepper;

      /**
       * @class
       * @augments {MultidimComponentMetropolisStepper}
       * A "subclass" of MultidimComponentMetropolisStepper making discretized Normal proposals.
       */
      var MultiIntComponentMetropolisStepper = function (params, state, log_post, options) {
        MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, IntMetropolisStepper);
      };
      MultiIntComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype);
      MultiIntComponentMetropolisStepper.prototype.constructor = MultiIntComponentMetropolisStepper;

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements a step for a binary parameter.
       * This is done by evaluating the log posterior for both states of the
       * parameter and then selecting a state randomly with probability relative 
       * to the posterior of each state.
       * @param params - An object with a single parameter definition.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
      */
      var BinaryStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length == 1) {
          this.param_name = param_names[0];
        } else {
          throw "BinaryStepper can't handle more than one parameter.";
        }
      };
      BinaryStepper.prototype = Object.create(Stepper.prototype);
      BinaryStepper.prototype.constructor = BinaryStepper;
      BinaryStepper.prototype.step = function () {
        this.state[this.param_name] = 0;
        var zero_log_dens = this.log_post();
        this.state[this.param_name] = 1;
        var one_log_dens = this.log_post();
        var max_log_dens = Math.max(zero_log_dens, one_log_dens);
        zero_log_dens -= max_log_dens;
        one_log_dens -= max_log_dens;
        var zero_prob = Math.exp(zero_log_dens - Math.log(Math.exp(zero_log_dens) + Math.exp(one_log_dens)));
        if (Math.random() < zero_prob) {
          this.state[this.param_name] = 0;
          return 0;
        } // else keep the param at 1 .
        return 1;
      };

      /**
      * @class
      * @implements {Stepper}
      * Just like MultidimComponentMetropolisStepper this Stepper takes a steps for
      * a multidimensional parameter by updating each component in turn. The difference
      * is that this stepper works on binary parameters.
      * @param params - An object with a single parameter definition for a 
      *   multidimensional parameter.
      * @param state - an object containing the state of all parameters.
      * @param log_post - A function that returns the log density that depends on the state. 
      * @param options - an object with options to the stepper.
      */
      var BinaryComponentStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length == 1) {
          this.param_name = param_names[0];
          var param = this.params[this.param_name];
          this.dim = param.dim;
        } else {
          throw "BinaryComponentStepper can't handle more than one parameter.";
        }
        var create_substeppers = function (dim, substate, log_post) {
          var substeppers = [];
          var i;
          if (dim.length === 1) {
            for (i = 0; i < dim[0]; i++) {
              var subparams = {};
              subparams[i] = param;
              substeppers[i] = new BinaryStepper(subparams, substate, log_post);
            }
          } else {
            for (i = 0; i < dim[0]; i++) {
              substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post);
            }
          }
          return substeppers;
        };
        this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post);
      };
      BinaryComponentStepper.prototype = Object.create(Stepper.prototype);
      BinaryComponentStepper.prototype.constructor = BinaryComponentStepper;
      BinaryComponentStepper.prototype.step = function () {
        // Go through the substeppers in a random order and call step() on them.
        return nested_array_random_apply(this.substeppers, function (substepper) {
          return substepper.step();
        });
      };

      /**
       * @class
       * @implements {Stepper}
       * This stepper can be responsible for taking a step for one or more parameters.
       * For real and int parameters it takes Metropolis within Gibbs steps, and for 
       * binary parameters it does evaluates the posterior for both paramter values and
       * randomly changes to a certain value proportionally to that value's posterior
       * (this is also done for each parameter, so also a * within Gibbs approach).
       * This stepper is also adaptive and can be efficient when the number of parameters
       * are not too high and the correlations between parameters are low.
       * @param params - An object with a one or more parameter definitions
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
      */
      var AmwgStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        this.param_names = Object.keys(this.params);
        this.substeppers = [];
        for (var i = 0; i < this.param_names.length; i++) {
          var param = params[this.param_names[i]];
          var SelectStepper;
          switch (param.type) {
            case "real":
              if (array_equal(param.dim, [1])) {
                SelectStepper = RealMetropolisStepper;
              } else {
                SelectStepper = MultiRealComponentMetropolisStepper;
              }
              break;
            case "int":
              if (array_equal(param.dim, [1])) {
                SelectStepper = IntMetropolisStepper;
              } else {
                SelectStepper = MultiIntComponentMetropolisStepper;
              }
              break;
            case "binary":
              if (array_equal(param.dim, [1])) {
                SelectStepper = BinaryStepper;
              } else {
                SelectStepper = BinaryComponentStepper;
              }
              break;
            default:
              throw "AmwgStepper can't handle parameter " + this.param_names[i] + " with type " + param.type;
          }
          var param_object_wrap = {};
          param_object_wrap[this.param_names[i]] = param;
          options = options || {};
          var param_options = options.params && options.params[this.param_names[i]] || {};
          param_options.prop_log_scale = param_options.prop_log_scale || options.prop_log_scale;
          param_options.batch_size = param_options.batch_size || options.batch_size;
          param_options.max_adaptation = param_options.max_adaptation || options.max_adaptation;
          param_options.initial_adaptation = param_options.initial_adaptation || options.initial_adaptation;
          param_options.target_accept_rate = param_options.target_accept_rate || options.target_accept_rate;
          param_options.is_adapting = param_options.is_adapting || options.is_adapting;
          this.substeppers[i] = new SelectStepper(param_object_wrap, state, log_post, param_options);
        }
      };
      AmwgStepper.prototype = Object.create(Stepper.prototype);
      AmwgStepper.prototype.constructor = AmwgStepper;
      AmwgStepper.prototype.step = function () {
        shuffle_array(this.substeppers);
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].step();
        }
        return this.state;
      };
      AmwgStepper.prototype.start_adaptation = function () {
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].start_adaptation();
        }
      };
      AmwgStepper.prototype.stop_adaptation = function () {
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].stop_adaptation();
        }
      };
      AmwgStepper.prototype.info = function () {
        var info = {};
        for (var i = 0; i < this.substeppers.length; i++) {
          info[this.param_names[i]] = this.substeppers[i].info();
        }
        return info;
      };

      /////////// Sampler Functions //////////
      ////////////////////////////////////////

      /**
      * @interface
      * While you could fit a model by pasting together Steppers, a
      // Sampler is here is a convenience class where an instance of Sampler
      // sets up the Steppers, checks the parameter definition,
      // and manages the sampling. This here defines the Sampler "interface".
      * @interface
      * @param params - An object with parameter definitions, for example:
      *   {"mu": {"type": "real"}, "sigma": {"type": "real", "lower" = 0}}
      *   The parameter definitions doesn't have to be "complete" and properties
      *   left out (like lower and upper) will be filled in by defaults.
      * @param log_post - A function with signature function(state, data). Here
      *   state will be an object representing the state with each parameter as a 
      *   key and the parameter values as numbers or arrays. For example:
      *   {"mu": 3, "sigma": 1.5}. The data argument will be the same object as 
      *   the data argument given below.
      * @param data - an object that will be passed on to the log_post function
      *   when sampling.
      * @param options - an object with options to the sampler.
      */
      var Sampler = function (params, log_post, data, options) {
        this.params = params;
        this.data = data;
        this.param_names = Object.keys(this.params);

        // Setting default options if not passed through the options object
        this.param_init_fun = get_option("param_init_fun", options, param_init_fixed);
        var thinning_interval = get_option("thin", options, 1);
        var params_to_monitor = get_option("monitor", options, null);
        this.thin(thinning_interval);
        this.monitor(params_to_monitor);
        this.options = options;
        // Completing the params and initializing the state.
        this.params = complete_params(this.params, this.param_init_fun);
        var state = {};
        for (var i = 0; i < this.param_names.length; i++) {
          state[this.param_names[i]] = this.params[this.param_names[i]].init;
        }
        this.log_post = function () {
          return log_post(state, data);
        };
        // Running the log_post function once in case it further modifies the state
        // for example adding derived quantities.
        this.log_post();
        this.state = state;
        this.steppers = this.create_stepper_ensamble(this.params, this.state, this.log_post, this.options);
      };

      /** Should return a vector of steppers that when called 
       * should take a step in the parameter space.
       */
      Sampler.prototype.create_stepper_ensamble = function (state, log_post) {
        throw "Every Sampler needs to implement create_stepper_ensamble()";
      };

      /** Returns an object with info about the state of the Sampler.
       */
      Sampler.prototype.info = function () {
        return {
          state: this.state,
          thin: this.thin,
          monitor: this.monitor,
          steppers: this.steppers
        };
      };

      /** Takes a step in the parameter space. Returns the new space
       * but also modifies the state in place.
       */
      Sampler.prototype.step = function () {
        shuffle_array(this.steppers);
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].step();
        }
        if (Object.keys(this.state).length > Object.keys(this.params).length) {
          // The state contains devived quantities (not only parameters) and we
          // need to run the log_post once more in order to set the derived quantities
          // for the final parameter state
          this.log_post();
        }
        return this.state;
      };

      /**
       * Takes n_iterations steps in the parameter space and returns them
       * as an object of arrays with one array per parameter. For example:
       * {mu: [1, -1, 2, 3, ...], sigma: [1, 2, 2, 1, ...]}.
       * If thin is > 1 then n_iterations / thin samples are returned.
       */
      Sampler.prototype.sample = function (n_iterations) {
        // Initializing curr_sample where the sample is going to be saved
        // as an object containing one array per parameter to be monitored.
        var i, j, monitored_params;
        if (this.monitored_params === null) {
          monitored_params = Object.keys(this.state);
        } else {
          monitored_params = this.monitored_params;
        }
        var curr_sample = {};
        for (j = 0; j < monitored_params.length; j++) {
          curr_sample[monitored_params[j]] = [];
        }
        for (i = 0; i < n_iterations; i++) {
          if (i % this.thinning_interval === 0) {
            for (j = 0; j < monitored_params.length; j++) {
              var param = monitored_params[j];
              curr_sample[param].push(clone_param_draw(this.state[param]));
            }
          }
          this.step();
        }
        return curr_sample;
      };

      /**
       * Takes n_iteration steps in parameter space but returns nothing.
       */
      Sampler.prototype.burn = function (n_iterations) {
        for (var i = 0; i < n_iterations; i++) {
          this.step();
        }
      };

      /**
       * Sets what parameters should be monitored and returned when calling
       * sample.
       */
      Sampler.prototype.monitor = function (params_to_monitor) {
        this.monitored_params = params_to_monitor;
      };

      /**
       * Sets the thinning. For example thin == 10 means that every 10th posterior
       * draw will be kept.
       */
      Sampler.prototype.thin = function (thinning_interval) {
        this.thinning_interval = thinning_interval;
      };

      /**
       * Sets adaptation on, if applicable, in all steppers.
       */
      Sampler.prototype.start_adaptation = function () {
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].start_adaptation();
        }
      };

      /**
      * Sets adaptation off, if applicable, in all steppers.
      */
      Sampler.prototype.stop_adaptation = function () {
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].stop_adaptation();
        }
      };

      /**
      * @class
      * @implements {Sampler}
      * This sampler uses the AmwgStepper as the stepper function which implements the 
      * Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
      * by Roberts and Rosenthal (2008). An adition is that it handles int parameters
      * by making discrete Normal proposals and binary parameters by taking on a new 
      * value proportional to the posterior of the two possible states of the
      * parameter. This sampler can be efficient when the number of parameters
      * are not too high and the correlations between parameters are low.
      * @param params - An object with a one or more parameter definitions
      * @param state - an object containing the state of all parameters.
      * @param log_post - A function that returns the log density that depends on the state. 
      * @param options - an object with options to the stepper.
      */
      var AmwgSampler = function (params, log_post, data, options) {
        Sampler.call(this, params, log_post, data, options);
      };
      AmwgSampler.prototype = Object.create(Sampler.prototype);
      AmwgSampler.prototype.constructor = AmwgSampler;
      AmwgSampler.prototype.create_stepper_ensamble = function (params, state, log_post, options) {
        return [new AmwgStepper(params, state, log_post, options)];
      };

      // Returning the functions that should be publicly exposed by this module
      return {
        runif: runif,
        runif_discrete: runif_discrete,
        rnorm: rnorm,
        param_init_fixed: param_init_fixed,
        complete_params: complete_params,
        RealMetropolisStepper: RealMetropolisStepper,
        IntMetropolisStepper: IntMetropolisStepper,
        MultiRealComponentMetropolisStepper: MultiRealComponentMetropolisStepper,
        MultiIntComponentMetropolisStepper: MultiIntComponentMetropolisStepper,
        BinaryStepper: BinaryStepper,
        BinaryComponentStepper: BinaryComponentStepper,
        AmwgStepper: AmwgStepper,
        AmwgSampler: AmwgSampler
      };
    });
  })(mcmc$1);
  var mcmcExports = mcmc$1.exports;

  function ascending$1(a, b) {
    return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
  }

  function* numbers(values, valueof) {
    {
      for (let value of values) {
        if (value != null && (value = +value) >= value) {
          yield value;
        }
      }
    }
  }

  function compareDefined(compare = ascending$1) {
    if (compare === ascending$1) return ascendingDefined;
    if (typeof compare !== "function") throw new TypeError("compare is not a function");
    return (a, b) => {
      const x = compare(a, b);
      if (x || x === 0) return x;
      return (compare(b, b) === 0) - (compare(a, a) === 0);
    };
  }
  function ascendingDefined(a, b) {
    return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);
  }

  function max(values, valueof) {
    let max;
    {
      for (const value of values) {
        if (value != null && (max < value || max === undefined && value >= value)) {
          max = value;
        }
      }
    }
    return max;
  }

  function min(values, valueof) {
    let min;
    {
      for (const value of values) {
        if (value != null && (min > value || min === undefined && value >= value)) {
          min = value;
        }
      }
    }
    return min;
  }

  // Based on https://github.com/mourner/quickselect
  // ISC license, Copyright 2018 Vladimir Agafonkin.
  function quickselect(array, k, left = 0, right = Infinity, compare) {
    k = Math.floor(k);
    left = Math.floor(Math.max(0, left));
    right = Math.floor(Math.min(array.length - 1, right));
    if (!(left <= k && k <= right)) return array;
    compare = compare === undefined ? ascendingDefined : compareDefined(compare);
    while (right > left) {
      if (right - left > 600) {
        const n = right - left + 1;
        const m = k - left + 1;
        const z = Math.log(n);
        const s = 0.5 * Math.exp(2 * z / 3);
        const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);
        const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));
        const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));
        quickselect(array, k, newLeft, newRight, compare);
      }
      const t = array[k];
      let i = left;
      let j = right;
      swap(array, left, k);
      if (compare(array[right], t) > 0) swap(array, left, right);
      while (i < j) {
        swap(array, i, j), ++i, --j;
        while (compare(array[i], t) < 0) ++i;
        while (compare(array[j], t) > 0) --j;
      }
      if (compare(array[left], t) === 0) swap(array, left, j);else ++j, swap(array, j, right);
      if (j <= k) left = j + 1;
      if (k <= j) right = j - 1;
    }
    return array;
  }
  function swap(array, i, j) {
    const t = array[i];
    array[i] = array[j];
    array[j] = t;
  }

  function quantile(values, p, valueof) {
    values = Float64Array.from(numbers(values));
    if (!(n = values.length) || isNaN(p = +p)) return;
    if (p <= 0 || n < 2) return min(values);
    if (p >= 1) return max(values);
    var n,
      i = (n - 1) * p,
      i0 = Math.floor(i),
      value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),
      value1 = min(values.subarray(i0 + 1));
    return value0 + (value1 - value0) * (i - i0);
  }

  function median(values, valueof) {
    return quantile(values, 0.5);
  }

  var noop = {
    value: () => {}
  };
  function dispatch() {
    for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {
      if (!(t = arguments[i] + "") || t in _ || /[\s.]/.test(t)) throw new Error("illegal type: " + t);
      _[t] = [];
    }
    return new Dispatch(_);
  }
  function Dispatch(_) {
    this._ = _;
  }
  function parseTypenames$1(typenames, types) {
    return typenames.trim().split(/^|\s+/).map(function (t) {
      var name = "",
        i = t.indexOf(".");
      if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
      if (t && !types.hasOwnProperty(t)) throw new Error("unknown type: " + t);
      return {
        type: t,
        name: name
      };
    });
  }
  Dispatch.prototype = dispatch.prototype = {
    constructor: Dispatch,
    on: function (typename, callback) {
      var _ = this._,
        T = parseTypenames$1(typename + "", _),
        t,
        i = -1,
        n = T.length;

      // If no callback was specified, return the callback of the given type and name.
      if (arguments.length < 2) {
        while (++i < n) if ((t = (typename = T[i]).type) && (t = get$1(_[t], typename.name))) return t;
        return;
      }

      // If a type was specified, set the callback for the given type and name.
      // Otherwise, if a null callback was specified, remove callbacks of the given name.
      if (callback != null && typeof callback !== "function") throw new Error("invalid callback: " + callback);
      while (++i < n) {
        if (t = (typename = T[i]).type) _[t] = set$1(_[t], typename.name, callback);else if (callback == null) for (t in _) _[t] = set$1(_[t], typename.name, null);
      }
      return this;
    },
    copy: function () {
      var copy = {},
        _ = this._;
      for (var t in _) copy[t] = _[t].slice();
      return new Dispatch(copy);
    },
    call: function (type, that) {
      if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];
      if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
      for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
    },
    apply: function (type, that, args) {
      if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
      for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
    }
  };
  function get$1(type, name) {
    for (var i = 0, n = type.length, c; i < n; ++i) {
      if ((c = type[i]).name === name) {
        return c.value;
      }
    }
  }
  function set$1(type, name, callback) {
    for (var i = 0, n = type.length; i < n; ++i) {
      if (type[i].name === name) {
        type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));
        break;
      }
    }
    if (callback != null) type.push({
      name: name,
      value: callback
    });
    return type;
  }

  var xhtml = "http://www.w3.org/1999/xhtml";
  var namespaces = {
    svg: "http://www.w3.org/2000/svg",
    xhtml: xhtml,
    xlink: "http://www.w3.org/1999/xlink",
    xml: "http://www.w3.org/XML/1998/namespace",
    xmlns: "http://www.w3.org/2000/xmlns/"
  };

  function namespace (name) {
    var prefix = name += "",
      i = prefix.indexOf(":");
    if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);
    return namespaces.hasOwnProperty(prefix) ? {
      space: namespaces[prefix],
      local: name
    } : name; // eslint-disable-line no-prototype-builtins
  }

  function creatorInherit(name) {
    return function () {
      var document = this.ownerDocument,
        uri = this.namespaceURI;
      return uri === xhtml && document.documentElement.namespaceURI === xhtml ? document.createElement(name) : document.createElementNS(uri, name);
    };
  }
  function creatorFixed(fullname) {
    return function () {
      return this.ownerDocument.createElementNS(fullname.space, fullname.local);
    };
  }
  function creator (name) {
    var fullname = namespace(name);
    return (fullname.local ? creatorFixed : creatorInherit)(fullname);
  }

  function none() {}
  function selector (selector) {
    return selector == null ? none : function () {
      return this.querySelector(selector);
    };
  }

  function selection_select (select) {
    if (typeof select !== "function") select = selector(select);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
        if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
          if ("__data__" in node) subnode.__data__ = node.__data__;
          subgroup[i] = subnode;
        }
      }
    }
    return new Selection$1(subgroups, this._parents);
  }

  // Given something array like (or null), returns something that is strictly an
  // array. This is used to ensure that array-like objects passed to d3.selectAll
  // or selection.selectAll are converted into proper arrays when creating a
  // selection; we don’t ever want to create a selection backed by a live
  // HTMLCollection or NodeList. However, note that selection.selectAll will use a
  // static NodeList as a group, since it safely derived from querySelectorAll.
  function array(x) {
    return x == null ? [] : Array.isArray(x) ? x : Array.from(x);
  }

  function empty() {
    return [];
  }
  function selectorAll (selector) {
    return selector == null ? empty : function () {
      return this.querySelectorAll(selector);
    };
  }

  function arrayAll(select) {
    return function () {
      return array(select.apply(this, arguments));
    };
  }
  function selection_selectAll (select) {
    if (typeof select === "function") select = arrayAll(select);else select = selectorAll(select);
    for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          subgroups.push(select.call(node, node.__data__, i, group));
          parents.push(node);
        }
      }
    }
    return new Selection$1(subgroups, parents);
  }

  function matcher (selector) {
    return function () {
      return this.matches(selector);
    };
  }
  function childMatcher(selector) {
    return function (node) {
      return node.matches(selector);
    };
  }

  var find = Array.prototype.find;
  function childFind(match) {
    return function () {
      return find.call(this.children, match);
    };
  }
  function childFirst() {
    return this.firstElementChild;
  }
  function selection_selectChild (match) {
    return this.select(match == null ? childFirst : childFind(typeof match === "function" ? match : childMatcher(match)));
  }

  var filter = Array.prototype.filter;
  function children() {
    return Array.from(this.children);
  }
  function childrenFilter(match) {
    return function () {
      return filter.call(this.children, match);
    };
  }
  function selection_selectChildren (match) {
    return this.selectAll(match == null ? children : childrenFilter(typeof match === "function" ? match : childMatcher(match)));
  }

  function selection_filter (match) {
    if (typeof match !== "function") match = matcher(match);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
        if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
          subgroup.push(node);
        }
      }
    }
    return new Selection$1(subgroups, this._parents);
  }

  function sparse (update) {
    return new Array(update.length);
  }

  function selection_enter () {
    return new Selection$1(this._enter || this._groups.map(sparse), this._parents);
  }
  function EnterNode(parent, datum) {
    this.ownerDocument = parent.ownerDocument;
    this.namespaceURI = parent.namespaceURI;
    this._next = null;
    this._parent = parent;
    this.__data__ = datum;
  }
  EnterNode.prototype = {
    constructor: EnterNode,
    appendChild: function (child) {
      return this._parent.insertBefore(child, this._next);
    },
    insertBefore: function (child, next) {
      return this._parent.insertBefore(child, next);
    },
    querySelector: function (selector) {
      return this._parent.querySelector(selector);
    },
    querySelectorAll: function (selector) {
      return this._parent.querySelectorAll(selector);
    }
  };

  function constant$1 (x) {
    return function () {
      return x;
    };
  }

  function bindIndex(parent, group, enter, update, exit, data) {
    var i = 0,
      node,
      groupLength = group.length,
      dataLength = data.length;

    // Put any non-null nodes that fit into update.
    // Put any null nodes into enter.
    // Put any remaining data into enter.
    for (; i < dataLength; ++i) {
      if (node = group[i]) {
        node.__data__ = data[i];
        update[i] = node;
      } else {
        enter[i] = new EnterNode(parent, data[i]);
      }
    }

    // Put any non-null nodes that don’t fit into exit.
    for (; i < groupLength; ++i) {
      if (node = group[i]) {
        exit[i] = node;
      }
    }
  }
  function bindKey(parent, group, enter, update, exit, data, key) {
    var i,
      node,
      nodeByKeyValue = new Map(),
      groupLength = group.length,
      dataLength = data.length,
      keyValues = new Array(groupLength),
      keyValue;

    // Compute the key for each node.
    // If multiple nodes have the same key, the duplicates are added to exit.
    for (i = 0; i < groupLength; ++i) {
      if (node = group[i]) {
        keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + "";
        if (nodeByKeyValue.has(keyValue)) {
          exit[i] = node;
        } else {
          nodeByKeyValue.set(keyValue, node);
        }
      }
    }

    // Compute the key for each datum.
    // If there a node associated with this key, join and add it to update.
    // If there is not (or the key is a duplicate), add it to enter.
    for (i = 0; i < dataLength; ++i) {
      keyValue = key.call(parent, data[i], i, data) + "";
      if (node = nodeByKeyValue.get(keyValue)) {
        update[i] = node;
        node.__data__ = data[i];
        nodeByKeyValue.delete(keyValue);
      } else {
        enter[i] = new EnterNode(parent, data[i]);
      }
    }

    // Add any remaining nodes that were not bound to data to exit.
    for (i = 0; i < groupLength; ++i) {
      if ((node = group[i]) && nodeByKeyValue.get(keyValues[i]) === node) {
        exit[i] = node;
      }
    }
  }
  function datum(node) {
    return node.__data__;
  }
  function selection_data (value, key) {
    if (!arguments.length) return Array.from(this, datum);
    var bind = key ? bindKey : bindIndex,
      parents = this._parents,
      groups = this._groups;
    if (typeof value !== "function") value = constant$1(value);
    for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {
      var parent = parents[j],
        group = groups[j],
        groupLength = group.length,
        data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),
        dataLength = data.length,
        enterGroup = enter[j] = new Array(dataLength),
        updateGroup = update[j] = new Array(dataLength),
        exitGroup = exit[j] = new Array(groupLength);
      bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);

      // Now connect the enter nodes to their following update node, such that
      // appendChild can insert the materialized enter node before this node,
      // rather than at the end of the parent node.
      for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {
        if (previous = enterGroup[i0]) {
          if (i0 >= i1) i1 = i0 + 1;
          while (!(next = updateGroup[i1]) && ++i1 < dataLength);
          previous._next = next || null;
        }
      }
    }
    update = new Selection$1(update, parents);
    update._enter = enter;
    update._exit = exit;
    return update;
  }

  // Given some data, this returns an array-like view of it: an object that
  // exposes a length property and allows numeric indexing. Note that unlike
  // selectAll, this isn’t worried about “live” collections because the resulting
  // array will only be used briefly while data is being bound. (It is possible to
  // cause the data to change while iterating by using a key function, but please
  // don’t; we’d rather avoid a gratuitous copy.)
  function arraylike(data) {
    return typeof data === "object" && "length" in data ? data // Array, TypedArray, NodeList, array-like
    : Array.from(data); // Map, Set, iterable, string, or anything else
  }

  function selection_exit () {
    return new Selection$1(this._exit || this._groups.map(sparse), this._parents);
  }

  function selection_join (onenter, onupdate, onexit) {
    var enter = this.enter(),
      update = this,
      exit = this.exit();
    if (typeof onenter === "function") {
      enter = onenter(enter);
      if (enter) enter = enter.selection();
    } else {
      enter = enter.append(onenter + "");
    }
    if (onupdate != null) {
      update = onupdate(update);
      if (update) update = update.selection();
    }
    if (onexit == null) exit.remove();else onexit(exit);
    return enter && update ? enter.merge(update).order() : update;
  }

  function selection_merge (context) {
    var selection = context.selection ? context.selection() : context;
    for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
      for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group0[i] || group1[i]) {
          merge[i] = node;
        }
      }
    }
    for (; j < m0; ++j) {
      merges[j] = groups0[j];
    }
    return new Selection$1(merges, this._parents);
  }

  function selection_order () {
    for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {
      for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {
        if (node = group[i]) {
          if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);
          next = node;
        }
      }
    }
    return this;
  }

  function selection_sort (compare) {
    if (!compare) compare = ascending;
    function compareNode(a, b) {
      return a && b ? compare(a.__data__, b.__data__) : !a - !b;
    }
    for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          sortgroup[i] = node;
        }
      }
      sortgroup.sort(compareNode);
    }
    return new Selection$1(sortgroups, this._parents).order();
  }
  function ascending(a, b) {
    return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
  }

  function selection_call () {
    var callback = arguments[0];
    arguments[0] = this;
    callback.apply(null, arguments);
    return this;
  }

  function selection_nodes () {
    return Array.from(this);
  }

  function selection_node () {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {
        var node = group[i];
        if (node) return node;
      }
    }
    return null;
  }

  function selection_size () {
    let size = 0;
    for (const node of this) ++size; // eslint-disable-line no-unused-vars
    return size;
  }

  function selection_empty () {
    return !this.node();
  }

  function selection_each (callback) {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
        if (node = group[i]) callback.call(node, node.__data__, i, group);
      }
    }
    return this;
  }

  function attrRemove$1(name) {
    return function () {
      this.removeAttribute(name);
    };
  }
  function attrRemoveNS$1(fullname) {
    return function () {
      this.removeAttributeNS(fullname.space, fullname.local);
    };
  }
  function attrConstant$1(name, value) {
    return function () {
      this.setAttribute(name, value);
    };
  }
  function attrConstantNS$1(fullname, value) {
    return function () {
      this.setAttributeNS(fullname.space, fullname.local, value);
    };
  }
  function attrFunction$1(name, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.removeAttribute(name);else this.setAttribute(name, v);
    };
  }
  function attrFunctionNS$1(fullname, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.removeAttributeNS(fullname.space, fullname.local);else this.setAttributeNS(fullname.space, fullname.local, v);
    };
  }
  function selection_attr (name, value) {
    var fullname = namespace(name);
    if (arguments.length < 2) {
      var node = this.node();
      return fullname.local ? node.getAttributeNS(fullname.space, fullname.local) : node.getAttribute(fullname);
    }
    return this.each((value == null ? fullname.local ? attrRemoveNS$1 : attrRemove$1 : typeof value === "function" ? fullname.local ? attrFunctionNS$1 : attrFunction$1 : fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, value));
  }

  function defaultView (node) {
    return node.ownerDocument && node.ownerDocument.defaultView // node is a Node
    || node.document && node // node is a Window
    || node.defaultView; // node is a Document
  }

  function styleRemove$1(name) {
    return function () {
      this.style.removeProperty(name);
    };
  }
  function styleConstant$1(name, value, priority) {
    return function () {
      this.style.setProperty(name, value, priority);
    };
  }
  function styleFunction$1(name, value, priority) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.style.removeProperty(name);else this.style.setProperty(name, v, priority);
    };
  }
  function selection_style (name, value, priority) {
    return arguments.length > 1 ? this.each((value == null ? styleRemove$1 : typeof value === "function" ? styleFunction$1 : styleConstant$1)(name, value, priority == null ? "" : priority)) : styleValue(this.node(), name);
  }
  function styleValue(node, name) {
    return node.style.getPropertyValue(name) || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);
  }

  function propertyRemove(name) {
    return function () {
      delete this[name];
    };
  }
  function propertyConstant(name, value) {
    return function () {
      this[name] = value;
    };
  }
  function propertyFunction(name, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) delete this[name];else this[name] = v;
    };
  }
  function selection_property (name, value) {
    return arguments.length > 1 ? this.each((value == null ? propertyRemove : typeof value === "function" ? propertyFunction : propertyConstant)(name, value)) : this.node()[name];
  }

  function classArray(string) {
    return string.trim().split(/^|\s+/);
  }
  function classList(node) {
    return node.classList || new ClassList(node);
  }
  function ClassList(node) {
    this._node = node;
    this._names = classArray(node.getAttribute("class") || "");
  }
  ClassList.prototype = {
    add: function (name) {
      var i = this._names.indexOf(name);
      if (i < 0) {
        this._names.push(name);
        this._node.setAttribute("class", this._names.join(" "));
      }
    },
    remove: function (name) {
      var i = this._names.indexOf(name);
      if (i >= 0) {
        this._names.splice(i, 1);
        this._node.setAttribute("class", this._names.join(" "));
      }
    },
    contains: function (name) {
      return this._names.indexOf(name) >= 0;
    }
  };
  function classedAdd(node, names) {
    var list = classList(node),
      i = -1,
      n = names.length;
    while (++i < n) list.add(names[i]);
  }
  function classedRemove(node, names) {
    var list = classList(node),
      i = -1,
      n = names.length;
    while (++i < n) list.remove(names[i]);
  }
  function classedTrue(names) {
    return function () {
      classedAdd(this, names);
    };
  }
  function classedFalse(names) {
    return function () {
      classedRemove(this, names);
    };
  }
  function classedFunction(names, value) {
    return function () {
      (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);
    };
  }
  function selection_classed (name, value) {
    var names = classArray(name + "");
    if (arguments.length < 2) {
      var list = classList(this.node()),
        i = -1,
        n = names.length;
      while (++i < n) if (!list.contains(names[i])) return false;
      return true;
    }
    return this.each((typeof value === "function" ? classedFunction : value ? classedTrue : classedFalse)(names, value));
  }

  function textRemove() {
    this.textContent = "";
  }
  function textConstant$1(value) {
    return function () {
      this.textContent = value;
    };
  }
  function textFunction$1(value) {
    return function () {
      var v = value.apply(this, arguments);
      this.textContent = v == null ? "" : v;
    };
  }
  function selection_text (value) {
    return arguments.length ? this.each(value == null ? textRemove : (typeof value === "function" ? textFunction$1 : textConstant$1)(value)) : this.node().textContent;
  }

  function htmlRemove() {
    this.innerHTML = "";
  }
  function htmlConstant(value) {
    return function () {
      this.innerHTML = value;
    };
  }
  function htmlFunction(value) {
    return function () {
      var v = value.apply(this, arguments);
      this.innerHTML = v == null ? "" : v;
    };
  }
  function selection_html (value) {
    return arguments.length ? this.each(value == null ? htmlRemove : (typeof value === "function" ? htmlFunction : htmlConstant)(value)) : this.node().innerHTML;
  }

  function raise() {
    if (this.nextSibling) this.parentNode.appendChild(this);
  }
  function selection_raise () {
    return this.each(raise);
  }

  function lower() {
    if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);
  }
  function selection_lower () {
    return this.each(lower);
  }

  function selection_append (name) {
    var create = typeof name === "function" ? name : creator(name);
    return this.select(function () {
      return this.appendChild(create.apply(this, arguments));
    });
  }

  function constantNull() {
    return null;
  }
  function selection_insert (name, before) {
    var create = typeof name === "function" ? name : creator(name),
      select = before == null ? constantNull : typeof before === "function" ? before : selector(before);
    return this.select(function () {
      return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);
    });
  }

  function remove() {
    var parent = this.parentNode;
    if (parent) parent.removeChild(this);
  }
  function selection_remove () {
    return this.each(remove);
  }

  function selection_cloneShallow() {
    var clone = this.cloneNode(false),
      parent = this.parentNode;
    return parent ? parent.insertBefore(clone, this.nextSibling) : clone;
  }
  function selection_cloneDeep() {
    var clone = this.cloneNode(true),
      parent = this.parentNode;
    return parent ? parent.insertBefore(clone, this.nextSibling) : clone;
  }
  function selection_clone (deep) {
    return this.select(deep ? selection_cloneDeep : selection_cloneShallow);
  }

  function selection_datum (value) {
    return arguments.length ? this.property("__data__", value) : this.node().__data__;
  }

  function contextListener(listener) {
    return function (event) {
      listener.call(this, event, this.__data__);
    };
  }
  function parseTypenames(typenames) {
    return typenames.trim().split(/^|\s+/).map(function (t) {
      var name = "",
        i = t.indexOf(".");
      if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
      return {
        type: t,
        name: name
      };
    });
  }
  function onRemove(typename) {
    return function () {
      var on = this.__on;
      if (!on) return;
      for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {
        if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {
          this.removeEventListener(o.type, o.listener, o.options);
        } else {
          on[++i] = o;
        }
      }
      if (++i) on.length = i;else delete this.__on;
    };
  }
  function onAdd(typename, value, options) {
    return function () {
      var on = this.__on,
        o,
        listener = contextListener(value);
      if (on) for (var j = 0, m = on.length; j < m; ++j) {
        if ((o = on[j]).type === typename.type && o.name === typename.name) {
          this.removeEventListener(o.type, o.listener, o.options);
          this.addEventListener(o.type, o.listener = listener, o.options = options);
          o.value = value;
          return;
        }
      }
      this.addEventListener(typename.type, listener, options);
      o = {
        type: typename.type,
        name: typename.name,
        value: value,
        listener: listener,
        options: options
      };
      if (!on) this.__on = [o];else on.push(o);
    };
  }
  function selection_on (typename, value, options) {
    var typenames = parseTypenames(typename + ""),
      i,
      n = typenames.length,
      t;
    if (arguments.length < 2) {
      var on = this.node().__on;
      if (on) for (var j = 0, m = on.length, o; j < m; ++j) {
        for (i = 0, o = on[j]; i < n; ++i) {
          if ((t = typenames[i]).type === o.type && t.name === o.name) {
            return o.value;
          }
        }
      }
      return;
    }
    on = value ? onAdd : onRemove;
    for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));
    return this;
  }

  function dispatchEvent(node, type, params) {
    var window = defaultView(node),
      event = window.CustomEvent;
    if (typeof event === "function") {
      event = new event(type, params);
    } else {
      event = window.document.createEvent("Event");
      if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;else event.initEvent(type, false, false);
    }
    node.dispatchEvent(event);
  }
  function dispatchConstant(type, params) {
    return function () {
      return dispatchEvent(this, type, params);
    };
  }
  function dispatchFunction(type, params) {
    return function () {
      return dispatchEvent(this, type, params.apply(this, arguments));
    };
  }
  function selection_dispatch (type, params) {
    return this.each((typeof params === "function" ? dispatchFunction : dispatchConstant)(type, params));
  }

  function* selection_iterator () {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
        if (node = group[i]) yield node;
      }
    }
  }

  var root = [null];
  function Selection$1(groups, parents) {
    this._groups = groups;
    this._parents = parents;
  }
  function selection() {
    return new Selection$1([[document.documentElement]], root);
  }
  function selection_selection() {
    return this;
  }
  Selection$1.prototype = selection.prototype = {
    constructor: Selection$1,
    select: selection_select,
    selectAll: selection_selectAll,
    selectChild: selection_selectChild,
    selectChildren: selection_selectChildren,
    filter: selection_filter,
    data: selection_data,
    enter: selection_enter,
    exit: selection_exit,
    join: selection_join,
    merge: selection_merge,
    selection: selection_selection,
    order: selection_order,
    sort: selection_sort,
    call: selection_call,
    nodes: selection_nodes,
    node: selection_node,
    size: selection_size,
    empty: selection_empty,
    each: selection_each,
    attr: selection_attr,
    style: selection_style,
    property: selection_property,
    classed: selection_classed,
    text: selection_text,
    html: selection_html,
    raise: selection_raise,
    lower: selection_lower,
    append: selection_append,
    insert: selection_insert,
    remove: selection_remove,
    clone: selection_clone,
    datum: selection_datum,
    on: selection_on,
    dispatch: selection_dispatch,
    [Symbol.iterator]: selection_iterator
  };

  function define (constructor, factory, prototype) {
    constructor.prototype = factory.prototype = prototype;
    prototype.constructor = constructor;
  }
  function extend(parent, definition) {
    var prototype = Object.create(parent.prototype);
    for (var key in definition) prototype[key] = definition[key];
    return prototype;
  }

  function Color() {}
  var darker = 0.7;
  var brighter = 1 / darker;
  var reI = "\\s*([+-]?\\d+)\\s*",
    reN = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",
    reP = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",
    reHex = /^#([0-9a-f]{3,8})$/,
    reRgbInteger = new RegExp(`^rgb\\(${reI},${reI},${reI}\\)$`),
    reRgbPercent = new RegExp(`^rgb\\(${reP},${reP},${reP}\\)$`),
    reRgbaInteger = new RegExp(`^rgba\\(${reI},${reI},${reI},${reN}\\)$`),
    reRgbaPercent = new RegExp(`^rgba\\(${reP},${reP},${reP},${reN}\\)$`),
    reHslPercent = new RegExp(`^hsl\\(${reN},${reP},${reP}\\)$`),
    reHslaPercent = new RegExp(`^hsla\\(${reN},${reP},${reP},${reN}\\)$`);
  var named = {
    aliceblue: 0xf0f8ff,
    antiquewhite: 0xfaebd7,
    aqua: 0x00ffff,
    aquamarine: 0x7fffd4,
    azure: 0xf0ffff,
    beige: 0xf5f5dc,
    bisque: 0xffe4c4,
    black: 0x000000,
    blanchedalmond: 0xffebcd,
    blue: 0x0000ff,
    blueviolet: 0x8a2be2,
    brown: 0xa52a2a,
    burlywood: 0xdeb887,
    cadetblue: 0x5f9ea0,
    chartreuse: 0x7fff00,
    chocolate: 0xd2691e,
    coral: 0xff7f50,
    cornflowerblue: 0x6495ed,
    cornsilk: 0xfff8dc,
    crimson: 0xdc143c,
    cyan: 0x00ffff,
    darkblue: 0x00008b,
    darkcyan: 0x008b8b,
    darkgoldenrod: 0xb8860b,
    darkgray: 0xa9a9a9,
    darkgreen: 0x006400,
    darkgrey: 0xa9a9a9,
    darkkhaki: 0xbdb76b,
    darkmagenta: 0x8b008b,
    darkolivegreen: 0x556b2f,
    darkorange: 0xff8c00,
    darkorchid: 0x9932cc,
    darkred: 0x8b0000,
    darksalmon: 0xe9967a,
    darkseagreen: 0x8fbc8f,
    darkslateblue: 0x483d8b,
    darkslategray: 0x2f4f4f,
    darkslategrey: 0x2f4f4f,
    darkturquoise: 0x00ced1,
    darkviolet: 0x9400d3,
    deeppink: 0xff1493,
    deepskyblue: 0x00bfff,
    dimgray: 0x696969,
    dimgrey: 0x696969,
    dodgerblue: 0x1e90ff,
    firebrick: 0xb22222,
    floralwhite: 0xfffaf0,
    forestgreen: 0x228b22,
    fuchsia: 0xff00ff,
    gainsboro: 0xdcdcdc,
    ghostwhite: 0xf8f8ff,
    gold: 0xffd700,
    goldenrod: 0xdaa520,
    gray: 0x808080,
    green: 0x008000,
    greenyellow: 0xadff2f,
    grey: 0x808080,
    honeydew: 0xf0fff0,
    hotpink: 0xff69b4,
    indianred: 0xcd5c5c,
    indigo: 0x4b0082,
    ivory: 0xfffff0,
    khaki: 0xf0e68c,
    lavender: 0xe6e6fa,
    lavenderblush: 0xfff0f5,
    lawngreen: 0x7cfc00,
    lemonchiffon: 0xfffacd,
    lightblue: 0xadd8e6,
    lightcoral: 0xf08080,
    lightcyan: 0xe0ffff,
    lightgoldenrodyellow: 0xfafad2,
    lightgray: 0xd3d3d3,
    lightgreen: 0x90ee90,
    lightgrey: 0xd3d3d3,
    lightpink: 0xffb6c1,
    lightsalmon: 0xffa07a,
    lightseagreen: 0x20b2aa,
    lightskyblue: 0x87cefa,
    lightslategray: 0x778899,
    lightslategrey: 0x778899,
    lightsteelblue: 0xb0c4de,
    lightyellow: 0xffffe0,
    lime: 0x00ff00,
    limegreen: 0x32cd32,
    linen: 0xfaf0e6,
    magenta: 0xff00ff,
    maroon: 0x800000,
    mediumaquamarine: 0x66cdaa,
    mediumblue: 0x0000cd,
    mediumorchid: 0xba55d3,
    mediumpurple: 0x9370db,
    mediumseagreen: 0x3cb371,
    mediumslateblue: 0x7b68ee,
    mediumspringgreen: 0x00fa9a,
    mediumturquoise: 0x48d1cc,
    mediumvioletred: 0xc71585,
    midnightblue: 0x191970,
    mintcream: 0xf5fffa,
    mistyrose: 0xffe4e1,
    moccasin: 0xffe4b5,
    navajowhite: 0xffdead,
    navy: 0x000080,
    oldlace: 0xfdf5e6,
    olive: 0x808000,
    olivedrab: 0x6b8e23,
    orange: 0xffa500,
    orangered: 0xff4500,
    orchid: 0xda70d6,
    palegoldenrod: 0xeee8aa,
    palegreen: 0x98fb98,
    paleturquoise: 0xafeeee,
    palevioletred: 0xdb7093,
    papayawhip: 0xffefd5,
    peachpuff: 0xffdab9,
    peru: 0xcd853f,
    pink: 0xffc0cb,
    plum: 0xdda0dd,
    powderblue: 0xb0e0e6,
    purple: 0x800080,
    rebeccapurple: 0x663399,
    red: 0xff0000,
    rosybrown: 0xbc8f8f,
    royalblue: 0x4169e1,
    saddlebrown: 0x8b4513,
    salmon: 0xfa8072,
    sandybrown: 0xf4a460,
    seagreen: 0x2e8b57,
    seashell: 0xfff5ee,
    sienna: 0xa0522d,
    silver: 0xc0c0c0,
    skyblue: 0x87ceeb,
    slateblue: 0x6a5acd,
    slategray: 0x708090,
    slategrey: 0x708090,
    snow: 0xfffafa,
    springgreen: 0x00ff7f,
    steelblue: 0x4682b4,
    tan: 0xd2b48c,
    teal: 0x008080,
    thistle: 0xd8bfd8,
    tomato: 0xff6347,
    turquoise: 0x40e0d0,
    violet: 0xee82ee,
    wheat: 0xf5deb3,
    white: 0xffffff,
    whitesmoke: 0xf5f5f5,
    yellow: 0xffff00,
    yellowgreen: 0x9acd32
  };
  define(Color, color, {
    copy(channels) {
      return Object.assign(new this.constructor(), this, channels);
    },
    displayable() {
      return this.rgb().displayable();
    },
    hex: color_formatHex,
    // Deprecated! Use color.formatHex.
    formatHex: color_formatHex,
    formatHex8: color_formatHex8,
    formatHsl: color_formatHsl,
    formatRgb: color_formatRgb,
    toString: color_formatRgb
  });
  function color_formatHex() {
    return this.rgb().formatHex();
  }
  function color_formatHex8() {
    return this.rgb().formatHex8();
  }
  function color_formatHsl() {
    return hslConvert(this).formatHsl();
  }
  function color_formatRgb() {
    return this.rgb().formatRgb();
  }
  function color(format) {
    var m, l;
    format = (format + "").trim().toLowerCase();
    return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000
    : l === 3 ? new Rgb(m >> 8 & 0xf | m >> 4 & 0xf0, m >> 4 & 0xf | m & 0xf0, (m & 0xf) << 4 | m & 0xf, 1) // #f00
    : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000
    : l === 4 ? rgba(m >> 12 & 0xf | m >> 8 & 0xf0, m >> 8 & 0xf | m >> 4 & 0xf0, m >> 4 & 0xf | m & 0xf0, ((m & 0xf) << 4 | m & 0xf) / 0xff) // #f000
    : null // invalid hex
    ) : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)
    : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)
    : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)
    : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)
    : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)
    : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)
    : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins
    : format === "transparent" ? new Rgb(NaN, NaN, NaN, 0) : null;
  }
  function rgbn(n) {
    return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);
  }
  function rgba(r, g, b, a) {
    if (a <= 0) r = g = b = NaN;
    return new Rgb(r, g, b, a);
  }
  function rgbConvert(o) {
    if (!(o instanceof Color)) o = color(o);
    if (!o) return new Rgb();
    o = o.rgb();
    return new Rgb(o.r, o.g, o.b, o.opacity);
  }
  function rgb(r, g, b, opacity) {
    return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);
  }
  function Rgb(r, g, b, opacity) {
    this.r = +r;
    this.g = +g;
    this.b = +b;
    this.opacity = +opacity;
  }
  define(Rgb, rgb, extend(Color, {
    brighter(k) {
      k = k == null ? brighter : Math.pow(brighter, k);
      return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
    },
    darker(k) {
      k = k == null ? darker : Math.pow(darker, k);
      return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
    },
    rgb() {
      return this;
    },
    clamp() {
      return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));
    },
    displayable() {
      return -0.5 <= this.r && this.r < 255.5 && -0.5 <= this.g && this.g < 255.5 && -0.5 <= this.b && this.b < 255.5 && 0 <= this.opacity && this.opacity <= 1;
    },
    hex: rgb_formatHex,
    // Deprecated! Use color.formatHex.
    formatHex: rgb_formatHex,
    formatHex8: rgb_formatHex8,
    formatRgb: rgb_formatRgb,
    toString: rgb_formatRgb
  }));
  function rgb_formatHex() {
    return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;
  }
  function rgb_formatHex8() {
    return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;
  }
  function rgb_formatRgb() {
    const a = clampa(this.opacity);
    return `${a === 1 ? "rgb(" : "rgba("}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? ")" : `, ${a})`}`;
  }
  function clampa(opacity) {
    return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));
  }
  function clampi(value) {
    return Math.max(0, Math.min(255, Math.round(value) || 0));
  }
  function hex(value) {
    value = clampi(value);
    return (value < 16 ? "0" : "") + value.toString(16);
  }
  function hsla(h, s, l, a) {
    if (a <= 0) h = s = l = NaN;else if (l <= 0 || l >= 1) h = s = NaN;else if (s <= 0) h = NaN;
    return new Hsl(h, s, l, a);
  }
  function hslConvert(o) {
    if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);
    if (!(o instanceof Color)) o = color(o);
    if (!o) return new Hsl();
    if (o instanceof Hsl) return o;
    o = o.rgb();
    var r = o.r / 255,
      g = o.g / 255,
      b = o.b / 255,
      min = Math.min(r, g, b),
      max = Math.max(r, g, b),
      h = NaN,
      s = max - min,
      l = (max + min) / 2;
    if (s) {
      if (r === max) h = (g - b) / s + (g < b) * 6;else if (g === max) h = (b - r) / s + 2;else h = (r - g) / s + 4;
      s /= l < 0.5 ? max + min : 2 - max - min;
      h *= 60;
    } else {
      s = l > 0 && l < 1 ? 0 : h;
    }
    return new Hsl(h, s, l, o.opacity);
  }
  function hsl(h, s, l, opacity) {
    return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);
  }
  function Hsl(h, s, l, opacity) {
    this.h = +h;
    this.s = +s;
    this.l = +l;
    this.opacity = +opacity;
  }
  define(Hsl, hsl, extend(Color, {
    brighter(k) {
      k = k == null ? brighter : Math.pow(brighter, k);
      return new Hsl(this.h, this.s, this.l * k, this.opacity);
    },
    darker(k) {
      k = k == null ? darker : Math.pow(darker, k);
      return new Hsl(this.h, this.s, this.l * k, this.opacity);
    },
    rgb() {
      var h = this.h % 360 + (this.h < 0) * 360,
        s = isNaN(h) || isNaN(this.s) ? 0 : this.s,
        l = this.l,
        m2 = l + (l < 0.5 ? l : 1 - l) * s,
        m1 = 2 * l - m2;
      return new Rgb(hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2), hsl2rgb(h, m1, m2), hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2), this.opacity);
    },
    clamp() {
      return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));
    },
    displayable() {
      return (0 <= this.s && this.s <= 1 || isNaN(this.s)) && 0 <= this.l && this.l <= 1 && 0 <= this.opacity && this.opacity <= 1;
    },
    formatHsl() {
      const a = clampa(this.opacity);
      return `${a === 1 ? "hsl(" : "hsla("}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? ")" : `, ${a})`}`;
    }
  }));
  function clamph(value) {
    value = (value || 0) % 360;
    return value < 0 ? value + 360 : value;
  }
  function clampt(value) {
    return Math.max(0, Math.min(1, value || 0));
  }

  /* From FvD 13.37, CSS Color Module Level 3 */
  function hsl2rgb(h, m1, m2) {
    return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255;
  }

  var constant = x => () => x;

  function linear(a, d) {
    return function (t) {
      return a + t * d;
    };
  }
  function exponential(a, b, y) {
    return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function (t) {
      return Math.pow(a + t * b, y);
    };
  }
  function gamma(y) {
    return (y = +y) === 1 ? nogamma : function (a, b) {
      return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);
    };
  }
  function nogamma(a, b) {
    var d = b - a;
    return d ? linear(a, d) : constant(isNaN(a) ? b : a);
  }

  var interpolateRgb = (function rgbGamma(y) {
    var color = gamma(y);
    function rgb$1(start, end) {
      var r = color((start = rgb(start)).r, (end = rgb(end)).r),
        g = color(start.g, end.g),
        b = color(start.b, end.b),
        opacity = nogamma(start.opacity, end.opacity);
      return function (t) {
        start.r = r(t);
        start.g = g(t);
        start.b = b(t);
        start.opacity = opacity(t);
        return start + "";
      };
    }
    rgb$1.gamma = rgbGamma;
    return rgb$1;
  })(1);

  function interpolateNumber (a, b) {
    return a = +a, b = +b, function (t) {
      return a * (1 - t) + b * t;
    };
  }

  var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,
    reB = new RegExp(reA.source, "g");
  function zero(b) {
    return function () {
      return b;
    };
  }
  function one(b) {
    return function (t) {
      return b(t) + "";
    };
  }
  function interpolateString (a, b) {
    var bi = reA.lastIndex = reB.lastIndex = 0,
      // scan index for next number in b
      am,
      // current match in a
      bm,
      // current match in b
      bs,
      // string preceding current number in b, if any
      i = -1,
      // index in s
      s = [],
      // string constants and placeholders
      q = []; // number interpolators

    // Coerce inputs to strings.
    a = a + "", b = b + "";

    // Interpolate pairs of numbers in a & b.
    while ((am = reA.exec(a)) && (bm = reB.exec(b))) {
      if ((bs = bm.index) > bi) {
        // a string precedes the next number in b
        bs = b.slice(bi, bs);
        if (s[i]) s[i] += bs; // coalesce with previous string
        else s[++i] = bs;
      }
      if ((am = am[0]) === (bm = bm[0])) {
        // numbers in a & b match
        if (s[i]) s[i] += bm; // coalesce with previous string
        else s[++i] = bm;
      } else {
        // interpolate non-matching numbers
        s[++i] = null;
        q.push({
          i: i,
          x: interpolateNumber(am, bm)
        });
      }
      bi = reB.lastIndex;
    }

    // Add remains of b.
    if (bi < b.length) {
      bs = b.slice(bi);
      if (s[i]) s[i] += bs; // coalesce with previous string
      else s[++i] = bs;
    }

    // Special optimization for only a single match.
    // Otherwise, interpolate each of the numbers and rejoin the string.
    return s.length < 2 ? q[0] ? one(q[0].x) : zero(b) : (b = q.length, function (t) {
      for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);
      return s.join("");
    });
  }

  var degrees = 180 / Math.PI;
  var identity = {
    translateX: 0,
    translateY: 0,
    rotate: 0,
    skewX: 0,
    scaleX: 1,
    scaleY: 1
  };
  function decompose (a, b, c, d, e, f) {
    var scaleX, scaleY, skewX;
    if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;
    if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;
    if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;
    if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;
    return {
      translateX: e,
      translateY: f,
      rotate: Math.atan2(b, a) * degrees,
      skewX: Math.atan(skewX) * degrees,
      scaleX: scaleX,
      scaleY: scaleY
    };
  }

  var svgNode;

  /* eslint-disable no-undef */
  function parseCss(value) {
    const m = new (typeof DOMMatrix === "function" ? DOMMatrix : WebKitCSSMatrix)(value + "");
    return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);
  }
  function parseSvg(value) {
    if (value == null) return identity;
    if (!svgNode) svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g");
    svgNode.setAttribute("transform", value);
    if (!(value = svgNode.transform.baseVal.consolidate())) return identity;
    value = value.matrix;
    return decompose(value.a, value.b, value.c, value.d, value.e, value.f);
  }

  function interpolateTransform(parse, pxComma, pxParen, degParen) {
    function pop(s) {
      return s.length ? s.pop() + " " : "";
    }
    function translate(xa, ya, xb, yb, s, q) {
      if (xa !== xb || ya !== yb) {
        var i = s.push("translate(", null, pxComma, null, pxParen);
        q.push({
          i: i - 4,
          x: interpolateNumber(xa, xb)
        }, {
          i: i - 2,
          x: interpolateNumber(ya, yb)
        });
      } else if (xb || yb) {
        s.push("translate(" + xb + pxComma + yb + pxParen);
      }
    }
    function rotate(a, b, s, q) {
      if (a !== b) {
        if (a - b > 180) b += 360;else if (b - a > 180) a += 360; // shortest path
        q.push({
          i: s.push(pop(s) + "rotate(", null, degParen) - 2,
          x: interpolateNumber(a, b)
        });
      } else if (b) {
        s.push(pop(s) + "rotate(" + b + degParen);
      }
    }
    function skewX(a, b, s, q) {
      if (a !== b) {
        q.push({
          i: s.push(pop(s) + "skewX(", null, degParen) - 2,
          x: interpolateNumber(a, b)
        });
      } else if (b) {
        s.push(pop(s) + "skewX(" + b + degParen);
      }
    }
    function scale(xa, ya, xb, yb, s, q) {
      if (xa !== xb || ya !== yb) {
        var i = s.push(pop(s) + "scale(", null, ",", null, ")");
        q.push({
          i: i - 4,
          x: interpolateNumber(xa, xb)
        }, {
          i: i - 2,
          x: interpolateNumber(ya, yb)
        });
      } else if (xb !== 1 || yb !== 1) {
        s.push(pop(s) + "scale(" + xb + "," + yb + ")");
      }
    }
    return function (a, b) {
      var s = [],
        // string constants and placeholders
        q = []; // number interpolators
      a = parse(a), b = parse(b);
      translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);
      rotate(a.rotate, b.rotate, s, q);
      skewX(a.skewX, b.skewX, s, q);
      scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);
      a = b = null; // gc
      return function (t) {
        var i = -1,
          n = q.length,
          o;
        while (++i < n) s[(o = q[i]).i] = o.x(t);
        return s.join("");
      };
    };
  }
  var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)");
  var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")");

  var frame = 0,
    // is an animation frame pending?
    timeout$1 = 0,
    // is a timeout pending?
    interval = 0,
    // are any timers active?
    pokeDelay = 1000,
    // how frequently we check for clock skew
    taskHead,
    taskTail,
    clockLast = 0,
    clockNow = 0,
    clockSkew = 0,
    clock = typeof performance === "object" && performance.now ? performance : Date,
    setFrame = typeof window === "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function (f) {
      setTimeout(f, 17);
    };
  function now() {
    return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);
  }
  function clearNow() {
    clockNow = 0;
  }
  function Timer() {
    this._call = this._time = this._next = null;
  }
  Timer.prototype = timer.prototype = {
    constructor: Timer,
    restart: function (callback, delay, time) {
      if (typeof callback !== "function") throw new TypeError("callback is not a function");
      time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);
      if (!this._next && taskTail !== this) {
        if (taskTail) taskTail._next = this;else taskHead = this;
        taskTail = this;
      }
      this._call = callback;
      this._time = time;
      sleep();
    },
    stop: function () {
      if (this._call) {
        this._call = null;
        this._time = Infinity;
        sleep();
      }
    }
  };
  function timer(callback, delay, time) {
    var t = new Timer();
    t.restart(callback, delay, time);
    return t;
  }
  function timerFlush() {
    now(); // Get the current time, if not already set.
    ++frame; // Pretend we’ve set an alarm, if we haven’t already.
    var t = taskHead,
      e;
    while (t) {
      if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);
      t = t._next;
    }
    --frame;
  }
  function wake() {
    clockNow = (clockLast = clock.now()) + clockSkew;
    frame = timeout$1 = 0;
    try {
      timerFlush();
    } finally {
      frame = 0;
      nap();
      clockNow = 0;
    }
  }
  function poke() {
    var now = clock.now(),
      delay = now - clockLast;
    if (delay > pokeDelay) clockSkew -= delay, clockLast = now;
  }
  function nap() {
    var t0,
      t1 = taskHead,
      t2,
      time = Infinity;
    while (t1) {
      if (t1._call) {
        if (time > t1._time) time = t1._time;
        t0 = t1, t1 = t1._next;
      } else {
        t2 = t1._next, t1._next = null;
        t1 = t0 ? t0._next = t2 : taskHead = t2;
      }
    }
    taskTail = t0;
    sleep(time);
  }
  function sleep(time) {
    if (frame) return; // Soonest alarm already set, or will be.
    if (timeout$1) timeout$1 = clearTimeout(timeout$1);
    var delay = time - clockNow; // Strictly less than if we recomputed clockNow.
    if (delay > 24) {
      if (time < Infinity) timeout$1 = setTimeout(wake, time - clock.now() - clockSkew);
      if (interval) interval = clearInterval(interval);
    } else {
      if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);
      frame = 1, setFrame(wake);
    }
  }

  function timeout (callback, delay, time) {
    var t = new Timer();
    delay = delay == null ? 0 : +delay;
    t.restart(elapsed => {
      t.stop();
      callback(elapsed + delay);
    }, delay, time);
    return t;
  }

  var emptyOn = dispatch("start", "end", "cancel", "interrupt");
  var emptyTween = [];
  var CREATED = 0;
  var SCHEDULED = 1;
  var STARTING = 2;
  var STARTED = 3;
  var RUNNING = 4;
  var ENDING = 5;
  var ENDED = 6;
  function schedule (node, name, id, index, group, timing) {
    var schedules = node.__transition;
    if (!schedules) node.__transition = {};else if (id in schedules) return;
    create(node, id, {
      name: name,
      index: index,
      // For context during callback.
      group: group,
      // For context during callback.
      on: emptyOn,
      tween: emptyTween,
      time: timing.time,
      delay: timing.delay,
      duration: timing.duration,
      ease: timing.ease,
      timer: null,
      state: CREATED
    });
  }
  function init(node, id) {
    var schedule = get(node, id);
    if (schedule.state > CREATED) throw new Error("too late; already scheduled");
    return schedule;
  }
  function set(node, id) {
    var schedule = get(node, id);
    if (schedule.state > STARTED) throw new Error("too late; already running");
    return schedule;
  }
  function get(node, id) {
    var schedule = node.__transition;
    if (!schedule || !(schedule = schedule[id])) throw new Error("transition not found");
    return schedule;
  }
  function create(node, id, self) {
    var schedules = node.__transition,
      tween;

    // Initialize the self timer when the transition is created.
    // Note the actual delay is not known until the first callback!
    schedules[id] = self;
    self.timer = timer(schedule, 0, self.time);
    function schedule(elapsed) {
      self.state = SCHEDULED;
      self.timer.restart(start, self.delay, self.time);

      // If the elapsed delay is less than our first sleep, start immediately.
      if (self.delay <= elapsed) start(elapsed - self.delay);
    }
    function start(elapsed) {
      var i, j, n, o;

      // If the state is not SCHEDULED, then we previously errored on start.
      if (self.state !== SCHEDULED) return stop();
      for (i in schedules) {
        o = schedules[i];
        if (o.name !== self.name) continue;

        // While this element already has a starting transition during this frame,
        // defer starting an interrupting transition until that transition has a
        // chance to tick (and possibly end); see d3/d3-transition#54!
        if (o.state === STARTED) return timeout(start);

        // Interrupt the active transition, if any.
        if (o.state === RUNNING) {
          o.state = ENDED;
          o.timer.stop();
          o.on.call("interrupt", node, node.__data__, o.index, o.group);
          delete schedules[i];
        }

        // Cancel any pre-empted transitions.
        else if (+i < id) {
          o.state = ENDED;
          o.timer.stop();
          o.on.call("cancel", node, node.__data__, o.index, o.group);
          delete schedules[i];
        }
      }

      // Defer the first tick to end of the current frame; see d3/d3#1576.
      // Note the transition may be canceled after start and before the first tick!
      // Note this must be scheduled before the start event; see d3/d3-transition#16!
      // Assuming this is successful, subsequent callbacks go straight to tick.
      timeout(function () {
        if (self.state === STARTED) {
          self.state = RUNNING;
          self.timer.restart(tick, self.delay, self.time);
          tick(elapsed);
        }
      });

      // Dispatch the start event.
      // Note this must be done before the tween are initialized.
      self.state = STARTING;
      self.on.call("start", node, node.__data__, self.index, self.group);
      if (self.state !== STARTING) return; // interrupted
      self.state = STARTED;

      // Initialize the tween, deleting null tween.
      tween = new Array(n = self.tween.length);
      for (i = 0, j = -1; i < n; ++i) {
        if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {
          tween[++j] = o;
        }
      }
      tween.length = j + 1;
    }
    function tick(elapsed) {
      var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),
        i = -1,
        n = tween.length;
      while (++i < n) {
        tween[i].call(node, t);
      }

      // Dispatch the end event.
      if (self.state === ENDING) {
        self.on.call("end", node, node.__data__, self.index, self.group);
        stop();
      }
    }
    function stop() {
      self.state = ENDED;
      self.timer.stop();
      delete schedules[id];
      for (var i in schedules) return; // eslint-disable-line no-unused-vars
      delete node.__transition;
    }
  }

  function interrupt (node, name) {
    var schedules = node.__transition,
      schedule,
      active,
      empty = true,
      i;
    if (!schedules) return;
    name = name == null ? null : name + "";
    for (i in schedules) {
      if ((schedule = schedules[i]).name !== name) {
        empty = false;
        continue;
      }
      active = schedule.state > STARTING && schedule.state < ENDING;
      schedule.state = ENDED;
      schedule.timer.stop();
      schedule.on.call(active ? "interrupt" : "cancel", node, node.__data__, schedule.index, schedule.group);
      delete schedules[i];
    }
    if (empty) delete node.__transition;
  }

  function selection_interrupt (name) {
    return this.each(function () {
      interrupt(this, name);
    });
  }

  function tweenRemove(id, name) {
    var tween0, tween1;
    return function () {
      var schedule = set(this, id),
        tween = schedule.tween;

      // If this node shared tween with the previous node,
      // just assign the updated shared tween and we’re done!
      // Otherwise, copy-on-write.
      if (tween !== tween0) {
        tween1 = tween0 = tween;
        for (var i = 0, n = tween1.length; i < n; ++i) {
          if (tween1[i].name === name) {
            tween1 = tween1.slice();
            tween1.splice(i, 1);
            break;
          }
        }
      }
      schedule.tween = tween1;
    };
  }
  function tweenFunction(id, name, value) {
    var tween0, tween1;
    if (typeof value !== "function") throw new Error();
    return function () {
      var schedule = set(this, id),
        tween = schedule.tween;

      // If this node shared tween with the previous node,
      // just assign the updated shared tween and we’re done!
      // Otherwise, copy-on-write.
      if (tween !== tween0) {
        tween1 = (tween0 = tween).slice();
        for (var t = {
            name: name,
            value: value
          }, i = 0, n = tween1.length; i < n; ++i) {
          if (tween1[i].name === name) {
            tween1[i] = t;
            break;
          }
        }
        if (i === n) tween1.push(t);
      }
      schedule.tween = tween1;
    };
  }
  function transition_tween (name, value) {
    var id = this._id;
    name += "";
    if (arguments.length < 2) {
      var tween = get(this.node(), id).tween;
      for (var i = 0, n = tween.length, t; i < n; ++i) {
        if ((t = tween[i]).name === name) {
          return t.value;
        }
      }
      return null;
    }
    return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));
  }
  function tweenValue(transition, name, value) {
    var id = transition._id;
    transition.each(function () {
      var schedule = set(this, id);
      (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);
    });
    return function (node) {
      return get(node, id).value[name];
    };
  }

  function interpolate (a, b) {
    var c;
    return (typeof b === "number" ? interpolateNumber : b instanceof color ? interpolateRgb : (c = color(b)) ? (b = c, interpolateRgb) : interpolateString)(a, b);
  }

  function attrRemove(name) {
    return function () {
      this.removeAttribute(name);
    };
  }
  function attrRemoveNS(fullname) {
    return function () {
      this.removeAttributeNS(fullname.space, fullname.local);
    };
  }
  function attrConstant(name, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = this.getAttribute(name);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function attrConstantNS(fullname, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = this.getAttributeNS(fullname.space, fullname.local);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function attrFunction(name, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0,
        value1 = value(this),
        string1;
      if (value1 == null) return void this.removeAttribute(name);
      string0 = this.getAttribute(name);
      string1 = value1 + "";
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function attrFunctionNS(fullname, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0,
        value1 = value(this),
        string1;
      if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);
      string0 = this.getAttributeNS(fullname.space, fullname.local);
      string1 = value1 + "";
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function transition_attr (name, value) {
    var fullname = namespace(name),
      i = fullname === "transform" ? interpolateTransformSvg : interpolate;
    return this.attrTween(name, typeof value === "function" ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, "attr." + name, value)) : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname) : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));
  }

  function attrInterpolate(name, i) {
    return function (t) {
      this.setAttribute(name, i.call(this, t));
    };
  }
  function attrInterpolateNS(fullname, i) {
    return function (t) {
      this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));
    };
  }
  function attrTweenNS(fullname, value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function attrTween(name, value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function transition_attrTween (name, value) {
    var key = "attr." + name;
    if (arguments.length < 2) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    var fullname = namespace(name);
    return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));
  }

  function delayFunction(id, value) {
    return function () {
      init(this, id).delay = +value.apply(this, arguments);
    };
  }
  function delayConstant(id, value) {
    return value = +value, function () {
      init(this, id).delay = value;
    };
  }
  function transition_delay (value) {
    var id = this._id;
    return arguments.length ? this.each((typeof value === "function" ? delayFunction : delayConstant)(id, value)) : get(this.node(), id).delay;
  }

  function durationFunction(id, value) {
    return function () {
      set(this, id).duration = +value.apply(this, arguments);
    };
  }
  function durationConstant(id, value) {
    return value = +value, function () {
      set(this, id).duration = value;
    };
  }
  function transition_duration (value) {
    var id = this._id;
    return arguments.length ? this.each((typeof value === "function" ? durationFunction : durationConstant)(id, value)) : get(this.node(), id).duration;
  }

  function easeConstant(id, value) {
    if (typeof value !== "function") throw new Error();
    return function () {
      set(this, id).ease = value;
    };
  }
  function transition_ease (value) {
    var id = this._id;
    return arguments.length ? this.each(easeConstant(id, value)) : get(this.node(), id).ease;
  }

  function easeVarying(id, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (typeof v !== "function") throw new Error();
      set(this, id).ease = v;
    };
  }
  function transition_easeVarying (value) {
    if (typeof value !== "function") throw new Error();
    return this.each(easeVarying(this._id, value));
  }

  function transition_filter (match) {
    if (typeof match !== "function") match = matcher(match);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
        if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
          subgroup.push(node);
        }
      }
    }
    return new Transition(subgroups, this._parents, this._name, this._id);
  }

  function transition_merge (transition) {
    if (transition._id !== this._id) throw new Error();
    for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
      for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group0[i] || group1[i]) {
          merge[i] = node;
        }
      }
    }
    for (; j < m0; ++j) {
      merges[j] = groups0[j];
    }
    return new Transition(merges, this._parents, this._name, this._id);
  }

  function start(name) {
    return (name + "").trim().split(/^|\s+/).every(function (t) {
      var i = t.indexOf(".");
      if (i >= 0) t = t.slice(0, i);
      return !t || t === "start";
    });
  }
  function onFunction(id, name, listener) {
    var on0,
      on1,
      sit = start(name) ? init : set;
    return function () {
      var schedule = sit(this, id),
        on = schedule.on;

      // If this node shared a dispatch with the previous node,
      // just assign the updated shared dispatch and we’re done!
      // Otherwise, copy-on-write.
      if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);
      schedule.on = on1;
    };
  }
  function transition_on (name, listener) {
    var id = this._id;
    return arguments.length < 2 ? get(this.node(), id).on.on(name) : this.each(onFunction(id, name, listener));
  }

  function removeFunction(id) {
    return function () {
      var parent = this.parentNode;
      for (var i in this.__transition) if (+i !== id) return;
      if (parent) parent.removeChild(this);
    };
  }
  function transition_remove () {
    return this.on("end.remove", removeFunction(this._id));
  }

  function transition_select (select) {
    var name = this._name,
      id = this._id;
    if (typeof select !== "function") select = selector(select);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
        if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
          if ("__data__" in node) subnode.__data__ = node.__data__;
          subgroup[i] = subnode;
          schedule(subgroup[i], name, id, i, subgroup, get(node, id));
        }
      }
    }
    return new Transition(subgroups, this._parents, name, id);
  }

  function transition_selectAll (select) {
    var name = this._name,
      id = this._id;
    if (typeof select !== "function") select = selectorAll(select);
    for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {
            if (child = children[k]) {
              schedule(child, name, id, k, children, inherit);
            }
          }
          subgroups.push(children);
          parents.push(node);
        }
      }
    }
    return new Transition(subgroups, parents, name, id);
  }

  var Selection = selection.prototype.constructor;
  function transition_selection () {
    return new Selection(this._groups, this._parents);
  }

  function styleNull(name, interpolate) {
    var string00, string10, interpolate0;
    return function () {
      var string0 = styleValue(this, name),
        string1 = (this.style.removeProperty(name), styleValue(this, name));
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : interpolate0 = interpolate(string00 = string0, string10 = string1);
    };
  }
  function styleRemove(name) {
    return function () {
      this.style.removeProperty(name);
    };
  }
  function styleConstant(name, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = styleValue(this, name);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function styleFunction(name, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0 = styleValue(this, name),
        value1 = value(this),
        string1 = value1 + "";
      if (value1 == null) string1 = value1 = (this.style.removeProperty(name), styleValue(this, name));
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function styleMaybeRemove(id, name) {
    var on0,
      on1,
      listener0,
      key = "style." + name,
      event = "end." + key,
      remove;
    return function () {
      var schedule = set(this, id),
        on = schedule.on,
        listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;

      // If this node shared a dispatch with the previous node,
      // just assign the updated shared dispatch and we’re done!
      // Otherwise, copy-on-write.
      if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);
      schedule.on = on1;
    };
  }
  function transition_style (name, value, priority) {
    var i = (name += "") === "transform" ? interpolateTransformCss : interpolate;
    return value == null ? this.styleTween(name, styleNull(name, i)).on("end.style." + name, styleRemove(name)) : typeof value === "function" ? this.styleTween(name, styleFunction(name, i, tweenValue(this, "style." + name, value))).each(styleMaybeRemove(this._id, name)) : this.styleTween(name, styleConstant(name, i, value), priority).on("end.style." + name, null);
  }

  function styleInterpolate(name, i, priority) {
    return function (t) {
      this.style.setProperty(name, i.call(this, t), priority);
    };
  }
  function styleTween(name, value, priority) {
    var t, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);
      return t;
    }
    tween._value = value;
    return tween;
  }
  function transition_styleTween (name, value, priority) {
    var key = "style." + (name += "");
    if (arguments.length < 2) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    return this.tween(key, styleTween(name, value, priority == null ? "" : priority));
  }

  function textConstant(value) {
    return function () {
      this.textContent = value;
    };
  }
  function textFunction(value) {
    return function () {
      var value1 = value(this);
      this.textContent = value1 == null ? "" : value1;
    };
  }
  function transition_text (value) {
    return this.tween("text", typeof value === "function" ? textFunction(tweenValue(this, "text", value)) : textConstant(value == null ? "" : value + ""));
  }

  function textInterpolate(i) {
    return function (t) {
      this.textContent = i.call(this, t);
    };
  }
  function textTween(value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && textInterpolate(i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function transition_textTween (value) {
    var key = "text";
    if (arguments.length < 1) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    return this.tween(key, textTween(value));
  }

  function transition_transition () {
    var name = this._name,
      id0 = this._id,
      id1 = newId();
    for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          var inherit = get(node, id0);
          schedule(node, name, id1, i, group, {
            time: inherit.time + inherit.delay + inherit.duration,
            delay: 0,
            duration: inherit.duration,
            ease: inherit.ease
          });
        }
      }
    }
    return new Transition(groups, this._parents, name, id1);
  }

  function transition_end () {
    var on0,
      on1,
      that = this,
      id = that._id,
      size = that.size();
    return new Promise(function (resolve, reject) {
      var cancel = {
          value: reject
        },
        end = {
          value: function () {
            if (--size === 0) resolve();
          }
        };
      that.each(function () {
        var schedule = set(this, id),
          on = schedule.on;

        // If this node shared a dispatch with the previous node,
        // just assign the updated shared dispatch and we’re done!
        // Otherwise, copy-on-write.
        if (on !== on0) {
          on1 = (on0 = on).copy();
          on1._.cancel.push(cancel);
          on1._.interrupt.push(cancel);
          on1._.end.push(end);
        }
        schedule.on = on1;
      });

      // The selection was empty, resolve end immediately
      if (size === 0) resolve();
    });
  }

  var id = 0;
  function Transition(groups, parents, name, id) {
    this._groups = groups;
    this._parents = parents;
    this._name = name;
    this._id = id;
  }
  function newId() {
    return ++id;
  }
  var selection_prototype = selection.prototype;
  Transition.prototype = {
    constructor: Transition,
    select: transition_select,
    selectAll: transition_selectAll,
    selectChild: selection_prototype.selectChild,
    selectChildren: selection_prototype.selectChildren,
    filter: transition_filter,
    merge: transition_merge,
    selection: transition_selection,
    transition: transition_transition,
    call: selection_prototype.call,
    nodes: selection_prototype.nodes,
    node: selection_prototype.node,
    size: selection_prototype.size,
    empty: selection_prototype.empty,
    each: selection_prototype.each,
    on: transition_on,
    attr: transition_attr,
    attrTween: transition_attrTween,
    style: transition_style,
    styleTween: transition_styleTween,
    text: transition_text,
    textTween: transition_textTween,
    remove: transition_remove,
    tween: transition_tween,
    delay: transition_delay,
    duration: transition_duration,
    ease: transition_ease,
    easeVarying: transition_easeVarying,
    end: transition_end,
    [Symbol.iterator]: selection_prototype[Symbol.iterator]
  };

  function cubicInOut(t) {
    return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;
  }

  var defaultTiming = {
    time: null,
    // Set on use.
    delay: 0,
    duration: 250,
    ease: cubicInOut
  };
  function inherit(node, id) {
    var timing;
    while (!(timing = node.__transition) || !(timing = timing[id])) {
      if (!(node = node.parentNode)) {
        throw new Error(`transition ${id} not found`);
      }
    }
    return timing;
  }
  function selection_transition (name) {
    var id, timing;
    if (name instanceof Transition) {
      id = name._id, name = name._name;
    } else {
      id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + "";
    }
    for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          schedule(node, name, id, i, group, timing || inherit(node, id));
        }
      }
    }
    return new Transition(groups, this._parents, name, id);
  }

  selection.prototype.interrupt = selection_interrupt;
  selection.prototype.transition = selection_transition;

  function Transform(k, x, y) {
    this.k = k;
    this.x = x;
    this.y = y;
  }
  Transform.prototype = {
    constructor: Transform,
    scale: function (k) {
      return k === 1 ? this : new Transform(this.k * k, this.x, this.y);
    },
    translate: function (x, y) {
      return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);
    },
    apply: function (point) {
      return [point[0] * this.k + this.x, point[1] * this.k + this.y];
    },
    applyX: function (x) {
      return x * this.k + this.x;
    },
    applyY: function (y) {
      return y * this.k + this.y;
    },
    invert: function (location) {
      return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];
    },
    invertX: function (x) {
      return (x - this.x) / this.k;
    },
    invertY: function (y) {
      return (y - this.y) / this.k;
    },
    rescaleX: function (x) {
      return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));
    },
    rescaleY: function (y) {
      return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));
    },
    toString: function () {
      return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")";
    }
  };
  Transform.prototype;

  /*
    HTDMath Static Class - Not intended for instantiation!

    Model parameters:
      k = discount factor (0, Infinity)

    Behavioral variables:
      A = amount
      D = delay
      V = subjective value

    Equations:
      V = A / (1 + kD)
      k = (A - V) / (VD)
  */
  class HTDMath {
    static k = {
      DEFAULT: 0.05,
      MIN: 0,
      MAX: 100,
      STEP: 0.001,
      JUMP: 0.01
    };
    static adk2v(a, d, k) {
      return a / (1 + k * d);
    }
    static adv2k(a, d, v) {
      return (a - v) / (v * d);
    }
  }

  // Internal dependencies

  /* eslint no-restricted-globals: ["off", "self"] */

  self.onmessage = event => {
    const params = {
      k: {
        type: 'real',
        lower: HTDMath.k.MIN,
        upper: HTDMath.k.MAX
      },
      luce: {
        type: 'real',
        lower: 0,
        upper: 100
      }
    };
    const logPost = (state, data) => {
      let lp = 0;

      // Priors
      const kMean = 2;
      const kShape = 3;
      lp += distributionsExports.gamma(state.k, kShape, kShape / kMean);
      // lp += BayesDistributions.unif(state.k, 0, 100);

      const luceMean = 2;
      const luceShape = 3;
      lp += distributionsExports.gamma(state.luce, luceShape, luceShape / luceMean);
      // lp += BayesDistributions.unif(state.luce, 0, 100);

      // Likelihood
      data.forEach(choice => {
        // Values
        const vs = HTDMath.adk2v(choice.as, choice.ds, state.k);
        const vl = HTDMath.adk2v(choice.al, choice.dl, state.k);

        // Choice of sooner or later is sampled from a Bernoulli distribution
        // Luce choice rule is used to compute probability of waiting! (0 = sooner, 1 = later)
        const binval = 1 / (1 + Math.exp(state.luce * (vs - vl)));

        // Actual response
        const response = choice.response === 'first' ? 0 : 1;
        lp += distributionsExports.bern(response, binval);
      });
      return lp;
    };

    // Initializing the sampler
    const sampler = new mcmcExports.AmwgSampler(params, logPost, event.data);
    // Burning some samples to the MCMC gods and sampling 5000 draws
    sampler.burn(1000);
    const samples = sampler.sample(5000);

    // Extract summary stats
    const results = {
      k: median(samples.k),
      luce: median(samples.luce)
    };
    self.postMessage({
      results: results,
      samples: samples
    });
  };

})();
//# sourceMappingURL=htd-fit-worker.js.map

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"htd-fit-worker.js","sources":["../../node_modules/bayes.js/distributions.js","../../node_modules/bayes.js/mcmc.js","../../node_modules/d3-array/src/ascending.js","../../node_modules/d3-array/src/number.js","../../node_modules/d3-array/src/sort.js","../../node_modules/d3-array/src/max.js","../../node_modules/d3-array/src/min.js","../../node_modules/d3-array/src/quickselect.js","../../node_modules/d3-array/src/quantile.js","../../node_modules/d3-array/src/median.js","../../node_modules/d3-dispatch/src/dispatch.js","../../node_modules/d3-selection/src/namespaces.js","../../node_modules/d3-selection/src/namespace.js","../../node_modules/d3-selection/src/creator.js","../../node_modules/d3-selection/src/selector.js","../../node_modules/d3-selection/src/selection/select.js","../../node_modules/d3-selection/src/array.js","../../node_modules/d3-selection/src/selectorAll.js","../../node_modules/d3-selection/src/selection/selectAll.js","../../node_modules/d3-selection/src/matcher.js","../../node_modules/d3-selection/src/selection/selectChild.js","../../node_modules/d3-selection/src/selection/selectChildren.js","../../node_modules/d3-selection/src/selection/filter.js","../../node_modules/d3-selection/src/selection/sparse.js","../../node_modules/d3-selection/src/selection/enter.js","../../node_modules/d3-selection/src/constant.js","../../node_modules/d3-selection/src/selection/data.js","../../node_modules/d3-selection/src/selection/exit.js","../../node_modules/d3-selection/src/selection/join.js","../../node_modules/d3-selection/src/selection/merge.js","../../node_modules/d3-selection/src/selection/order.js","../../node_modules/d3-selection/src/selection/sort.js","../../node_modules/d3-selection/src/selection/call.js","../../node_modules/d3-selection/src/selection/nodes.js","../../node_modules/d3-selection/src/selection/node.js","../../node_modules/d3-selection/src/selection/size.js","../../node_modules/d3-selection/src/selection/empty.js","../../node_modules/d3-selection/src/selection/each.js","../../node_modules/d3-selection/src/selection/attr.js","../../node_modules/d3-selection/src/window.js","../../node_modules/d3-selection/src/selection/style.js","../../node_modules/d3-selection/src/selection/property.js","../../node_modules/d3-selection/src/selection/classed.js","../../node_modules/d3-selection/src/selection/text.js","../../node_modules/d3-selection/src/selection/html.js","../../node_modules/d3-selection/src/selection/raise.js","../../node_modules/d3-selection/src/selection/lower.js","../../node_modules/d3-selection/src/selection/append.js","../../node_modules/d3-selection/src/selection/insert.js","../../node_modules/d3-selection/src/selection/remove.js","../../node_modules/d3-selection/src/selection/clone.js","../../node_modules/d3-selection/src/selection/datum.js","../../node_modules/d3-selection/src/selection/on.js","../../node_modules/d3-selection/src/selection/dispatch.js","../../node_modules/d3-selection/src/selection/iterator.js","../../node_modules/d3-selection/src/selection/index.js","../../node_modules/d3-color/src/define.js","../../node_modules/d3-color/src/color.js","../../node_modules/d3-interpolate/src/constant.js","../../node_modules/d3-interpolate/src/color.js","../../node_modules/d3-interpolate/src/rgb.js","../../node_modules/d3-interpolate/src/number.js","../../node_modules/d3-interpolate/src/string.js","../../node_modules/d3-interpolate/src/transform/decompose.js","../../node_modules/d3-interpolate/src/transform/parse.js","../../node_modules/d3-interpolate/src/transform/index.js","../../node_modules/d3-timer/src/timer.js","../../node_modules/d3-timer/src/timeout.js","../../node_modules/d3-transition/src/transition/schedule.js","../../node_modules/d3-transition/src/interrupt.js","../../node_modules/d3-transition/src/selection/interrupt.js","../../node_modules/d3-transition/src/transition/tween.js","../../node_modules/d3-transition/src/transition/interpolate.js","../../node_modules/d3-transition/src/transition/attr.js","../../node_modules/d3-transition/src/transition/attrTween.js","../../node_modules/d3-transition/src/transition/delay.js","../../node_modules/d3-transition/src/transition/duration.js","../../node_modules/d3-transition/src/transition/ease.js","../../node_modules/d3-transition/src/transition/easeVarying.js","../../node_modules/d3-transition/src/transition/filter.js","../../node_modules/d3-transition/src/transition/merge.js","../../node_modules/d3-transition/src/transition/on.js","../../node_modules/d3-transition/src/transition/remove.js","../../node_modules/d3-transition/src/transition/select.js","../../node_modules/d3-transition/src/transition/selectAll.js","../../node_modules/d3-transition/src/transition/selection.js","../../node_modules/d3-transition/src/transition/style.js","../../node_modules/d3-transition/src/transition/styleTween.js","../../node_modules/d3-transition/src/transition/text.js","../../node_modules/d3-transition/src/transition/textTween.js","../../node_modules/d3-transition/src/transition/transition.js","../../node_modules/d3-transition/src/transition/end.js","../../node_modules/d3-transition/src/transition/index.js","../../node_modules/d3-ease/src/cubic.js","../../node_modules/d3-transition/src/selection/transition.js","../../node_modules/d3-transition/src/selection/index.js","../../node_modules/d3-zoom/src/transform.js","../discountable-math/src/htd-math.js","../discountable-math/src/index.js","src/components/htd-fit-worker.js"],"sourcesContent":["\"use strict\";\n\n\n// A number of log probability density functions (PDF). Naming and parameterization\n// should match R's, except for that all functions reside in an ld object (\n// as in \"log density\"), so to get a normal log density you would write\n// ld.norm(...).\n// Most of the code below is directly taken from the great Jstat project\n// (https://github.com/jstat/) which includes PDF for many common probability\n// distributions. What I have done is only to convert these to log PDFs.\n\n/*\nOriginal work Copyright (c) 2013 jStat\nModified work Copyright (c) 2015 Rasmus Bååth \n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n\n*/\n\n\n// This boiler plate code here is taken from:\n// https://github.com/umdjs/umd/blob/master/templates/returnExports.js\n// It should make shure that module can be imported both in the browser,\n// Node, and by using the Asynchronous Module Definition standard.\n// If this module is loaded in the browser it will created the global\n// object ld .\n(function (root, factory) {\n    if (typeof define === 'function' && define.amd) {\n        // AMD. Register as an anonymous module.\n        define([], factory);\n    } else if (typeof module === 'object' && module.exports) {\n        // Node. Does not work with strict CommonJS, but\n        // only CommonJS-like environments that support module.exports,\n        // like Node.\n        module.exports = factory();\n    } else {\n        // Browser globals (root is window)\n        root.ld = factory();\n  }\n}(this, function() {\n  // Object to hold the functions to be exported.\n  var ld  = {};\n  \n  ////////// Helper functions //////////\n  //////////////////////////////////////\n  \n  var lgamma = function(x) {\n    var j = 0;\n    var cof = [\n      76.18009172947146, -86.50532032941677, 24.01409824083091,\n      -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5\n    ];\n    var ser = 1.000000000190015;\n    var xx, y, tmp;\n    tmp = (y = xx = x) + 5.5;\n    tmp -= (xx + 0.5) * log(tmp);\n    for (; j < 6; j++)\n      ser += cof[j] / ++y;\n    return log(2.5066282746310005 * ser / xx) - tmp;\n  };\n  ld.lgamma = lgamma;\n  \n  var lfactorial = function(n) {\n    return n < 0 ? NaN : lgamma(n + 1);\n  };\n  ld.lfactorial = lfactorial;\n  \n  var lchoose = function(n, k){\n    return lfactorial(n) - lfactorial(k) - lfactorial(n - k);\n  };\n  ld.lchoose = lchoose;\n  \n  var lbeta = function(a, b) {\n    return lgamma(a) + lgamma(b) - lgamma(a + b);\n  };\n  ld.lbeta = lbeta;\n  \n  var log  = Math.log;\n  var exp  = Math.exp;\n  var abs  = Math.abs;\n  var pow  = Math.pow;\n  var sqrt = Math.sqrt;\n  var pi   = Math.PI;\n  \n  ////////// Continous distributions //////////\n  /////////////////////////////////////////////\n  \n  ld.beta = function(x, shape1, shape2) {\n    if (x > 1 || x < 0) {\n        return -Infinity;\n    }\n    if(shape1 === 1 && shape2 === 1) {\n      return 0;\n    } else {\n      return (shape1 - 1) * log(x) + (shape2 - 1) * log(1 - x) - lbeta(shape1, shape2);  \n    }\n  };\n  \n  ld.cauchy = function(x, location, scale) {\n    return log(scale) - log(pow(x - location, 2) + pow(scale, 2))  - log(pi);\n  };\n  \n  ld.norm = function(x, mean, sd) {\n      return -0.5 * log(2 * pi) -log(sd) - pow(x - mean, 2) / (2 * sd * sd);\n  };\n\n  // A bivariate Normal distribution parameterized by arrays of two means and SDs, and \n  // the correlation.\n  ld.bivarnorm = function(x, mean, sd, corr) {\n    var z = pow(x[0] - mean[0], 2) / pow(sd[0], 2) +\n            pow(x[1] - mean[1], 2) / pow(sd[1], 2) - \n            (2 * corr * (x[0] - mean[0]) * (x[1] - mean[1])) / (sd[0] * sd[1]);\n    var normalizing_factor = -( log(2) + log(pi) + log(sd[0]) + log(sd[1]) + \n                                0.5 * log(1 - pow(corr, 2)) ); \n    var bivar_log_dens = normalizing_factor - z / (2 * (1 - pow(corr, 2) ) ); \n    return bivar_log_dens;\n  };\n  \n\n  ld.laplace = function(x, location, scale) {\n    return (-abs(x - location)/scale) - log(2 * scale);\n  };\n  \n  ld.dexp = ld.laplace;\n  \n  ld.gamma = function(x, shape, rate) {\n    var scale = 1 / rate;\n    if (x < 0) {\n      return -Infinity;\n    }\n    if((x === 0 && shape === 1) ) {\n      return -log(scale);\n    } else {\n      return (shape - 1) * log(x) - x / scale - lgamma(shape) - shape * log(scale);\n    }\n  };\n  \n  ld.invgamma = function(x, shape, scale) {\n      if (x <= 0) {\n        return -Infinity;\n      }\n      return -(shape + 1) * log(x) - scale / x - lgamma(shape) + shape * log(scale);\n    };\n  \n  ld.lnorm =  function(x, meanlog, sdlog) {\n    if (x <= 0) {\n      return -Infinity;\n    }\n    return -log(x) - 0.5 * log(2 * pi) - log(sdlog) - \n            pow(log(x) - meanlog, 2) / (2 * sdlog * sdlog);\n  };\n  \n  ld.pareto = function(x, scale, shape) {\n    if (x < scale) {\n      return -Infinity;\n    }\n    return log(shape) + shape * log(scale) - (shape + 1) * log(x);\n  };\n  \n  ld.t  =  function(x, location, scale, df) {\n    df = df > 1e100 ? 1e100 : df;\n    return lgamma((df + 1)/2) - lgamma(df/2) - log(sqrt(pi * df) * scale) +\n           log(pow(1 + (1/df) * pow((x - location)/scale, 2), -(df + 1)/2));\n  };\n  \n  // This is a direct javascript translation of the R code used to evaluate\n  // the log density of a weibull distribution: \n  // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dweibull.c\n  ld.weibull = function(x, shape, scale) {\n    if (x < 0) return -Infinity;\n    if(x === 0 && shape < 1) return Infinity;\n    var tmp1 = pow(x / scale, shape - 1);\n    var tmp2 = tmp1 * (x / scale);\n\t  return -tmp2 + log(shape * tmp1 / scale);\n  };\n  \n  // This is a direct javascript translation of the R code used to evaluate\n  // the log density of a logistic distribution: \n  // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dlogis.c\n  ld.logis = function(x, location, scale) {\n    x = abs((x - location) / scale);\n    var e = exp(-x);\n    var f = 1.0 + e;\n    return -(x + log(scale * f * f));    \n  };\n\n  ld.dirichlet = function(x, alpha) {\n    var sum_alpha = 0;\n    var sum_lgamma_alpha = 0;\n    var sum_alpha_sub_1_log_x = 0;\n    var n = alpha.length;\n    for(var i = 0; i < n; i++) {\n      sum_alpha += alpha[i];\n      sum_lgamma_alpha += lgamma(alpha[i]);\n      sum_alpha_sub_1_log_x += (alpha[i] - 1) * log(x[i]);\n    }\n    return lgamma(sum_alpha) - sum_lgamma_alpha + sum_alpha_sub_1_log_x;\n  };\n   \n    \n  ld.exp = function(x, rate) {\n      return x < 0 ? -Infinity : log(rate) -rate * x;\n  };\n  \n  ld.unif = function(x, min, max) {\n      return (x < min || x > max) ? -Infinity : log(1 / (max - min));\n  };\n  \n  ////////// Discrete distributions //////////\n  ////////////////////////////////////////////\n  \n  ld.bern = function(x, prob) {\n      return !(x === 0 || x === 1) ? -Infinity : log(x * prob + (1 - x) * (1 - prob));\n  };\n  \n  ld.cat = function(x, probs) {\n    if(x < 1 || x > probs.length) {\n      return -Infinity;\n    } else {\n      return log( probs[x - 1] );\n    }\n  };\n  \n  ld.binom = function(x, size, prob) {\n    if(x > size || x < 0) {\n      return -Infinity;\n    }\n    if(prob === 0 || prob === 1) {\n      return (size * prob) === x ? 0 : -Infinity;\n    }\n    return lchoose(size, x) + x * log(prob) + (size - x) * log(1 - prob);\n  };\n  \n  var multinom = function(x, probs) {\n    var n = x.length;\n    var size = 0;\n    var tmp_term = 0;\n    for(var i = 0; i < n; i++) {\n      if(probs[i] === 0) {\n        if(x[i] !== 0) {\n          return -Infinity;  \n        }\n      } else {\n        size += x[i];\n        tmp_term += x[i] * log(probs[i]) - lgamma(x[i] + 1);\n      }\n    }\n    return lgamma(size + 1) + tmp_term ;\n  };\n  \n  ld.nbinom = function(x, size, prob) {\n    if(x < 0) {\n      return -Infinity;\n    }\n    return lchoose(x + size - 1, size - 1) + x * log(1 - prob) + size * log(prob);\n  };\n  \n  ld.hyper = function(x, m, n, k) {\n    if(x < 0 || x > k) {\n      return -Infinity;\n    } else {\n    return lchoose(m, x) + lchoose(n, k-x) - lchoose(m+n, k);\n    }\n  };\n  \n  ld.pois = function(x, lambda) {\n      return x < 0 ? -Infinity : log(lambda) * x - lambda - lfactorial(x);\n  };\n  \n  return ld;\n}));","\"use strict\";\n\n// This boiler plate code here is taken from:\n// https://github.com/umdjs/umd/blob/master/templates/returnExports.js\n// It should make shure that module can be imported both in the browser,\n// Node, and by using the Asynchronous Module Definition standard.\n// If this module is loaded in the browser it will created the global\n// object mcmc .\n(function (root, factory) {\n    if (typeof define === 'function' && define.amd) {\n        // AMD. Register as an anonymous module.\n        define([], factory);\n    } else if (typeof module === 'object' && module.exports) {\n        // Node. Does not work with strict CommonJS, but\n        // only CommonJS-like environments that support module.exports,\n        // like Node.\n        module.exports = factory();\n    } else {\n        // Browser globals (root is window)\n        root.mcmc = factory();\n  }\n}(this, function(){\n\n/// The actual module code starts here ///\n//////////////////////////////////////////  \n  \n  ////////// Helper Functions //////////\n  //////////////////////////////////////\n  \n  /** Returns a random real number between min and max */\n  var runif = function(min, max) {\n    return Math.random() * (max - min) + min;\n  };\n  \n  /** Returns a random integer between min and max */\n  var runif_discrete = function(min, max) {\n    return Math.floor(Math.random() * (max - min + 1)) + min;\n  };\n  \n  /** Returns a random real number from a normal distribbution defined\n   *  by mean and sd. \n   *  Adapted from https://github.com/jstat/jstat/blob/master/src/special.js */\n  var rnorm = function(mean, sd) {\n    var u, v, x, y, q;\n    do {\n      u = Math.random();\n      v = 1.7156 * (Math.random() - 0.5);\n      x = u - 0.449871;\n      y = Math.abs(v) + 0.386595;\n      q = x * x + y * (0.19600 * y - 0.25472 * x);\n    } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u));\n    \n    return (v / u) * sd + mean;\n  };\n  \n  \n  /** Returns a deep clone of src, sort of... It only copies a limited\n   * number of types and, for example, function are not copied. \n   * From http://davidwalsh.name/javascript-clone\n   */\n  var deep_clone = function(src) {\n  \tfunction mixin(dest, source, copyFunc) {\n  \t\tvar name, s, i, empty = {};\n  \t\tfor(name in source){\n  \t\t\t// the (!(name in empty) || empty[name] !== s) condition avoids copying properties in \"source\"\n  \t\t\t// inherited from Object.prototype.\t For example, if dest has a custom toString() method,\n  \t\t\t// don't overwrite it with the toString() method that source inherited from Object.prototype\n  \t\t\ts = source[name];\n  \t\t\tif(!(name in dest) || (dest[name] !== s && (!(name in empty) || empty[name] !== s))){\n  \t\t\t\tdest[name] = copyFunc ? copyFunc(s) : s;\n  \t\t\t}\n  \t\t}\n  \t\treturn dest;\n  \t}\n  \tif(!src || typeof src != \"object\" || Object.prototype.toString.call(src) === \"[object Function]\"){\n  \t\t// null, undefined, any non-object, or function\n  \t\treturn src;\t// anything\n  \t}\n  \tif(src.nodeType && \"cloneNode\" in src){\n  \t\t// DOM Node\n  \t\treturn src.cloneNode(true); // Node\n  \t}\n  \tif(src instanceof Date){\n  \t\t// Date\n  \t\treturn new Date(src.getTime());\t// Date\n  \t}\n  \tif(src instanceof RegExp){\n  \t\t// RegExp\n  \t\treturn new RegExp(src);   // RegExp\n  \t}\n  \tvar r, i, l;\n  \tif(src instanceof Array){\n  \t\t// array\n  \t\tr = [];\n  \t\tfor(i = 0, l = src.length; i < l; ++i){\n  \t\t\tif(i in src){\n  \t\t\t\tr.push(deep_clone(src[i]));\n  \t\t\t}\n  \t\t}\n  \t} else {\n  \t\t// generic objects\n  \t\tr = src.constructor ? new src.constructor() : {};\n  \t}\n  \treturn mixin(r, src, deep_clone);\n  };\n  \n  /** Specialized clone function that only clones scalars and nested arrays where\n   * each array either consists of all arrays or all numbers. This function\n   * is meant as a fast way of cloning parameter draws within the mcmc sampling\n   * loop.\n   */\n  var clone_param_draw = function(x) {\n    if(Array.isArray(x)) {\n      if(Array.isArray(x[0])) {\n        // x is an array of arrays so we need to clone it recursively\n        var x_copy = [];\n        for(var i = 0, length = x.length; i < length; i++) {\n          x_copy.push(clone_param_draw(x[i]));\n        } \n        return x_copy;\n      } else { // We'll assume x is a arrays of scalars\n        return x.slice(0);\n      }\n    } else { // We'll assume x is a scalar\n      return x;\n    }\n  };\n  \n  /** Returns true if object is a number.\n   */\n  var is_number = function(object) {\n      return typeof object == \"number\" || (typeof object == \"object\" && object.constructor === Number);\n  };\n  \n  /**\n   * Creates and initializes a (possibly multidimensional/nested) array.\n   * @param dim - An array giving the dimension of the array. For example,\n   *   [5] would yield a 5 element array, and [3,3] would yield a 3 by 3 matrix.\n   * @param init - A value or a function used to fill in the each element in\n   *   the array. If it is a function it should take no arguments, it will be \n   *   evaluated once for each element, and it's return value will be used to\n   *   fill in each element.\n   * @example \n   * // The following would return [[1,1],[1,1],[1,1]]\n   * create_array([2,3], 1)\n   */\n  var create_array = function(dim, init) {\n    var arr = new Array(dim[0]);\n    var i;\n    if(dim.length == 1) { // Fill it up with init\n      if(typeof init === \"function\") {\n        for(i = 0; i < dim[0]; i++) {\n          arr[i] = init();\n        }  \n      } else {\n        for(i = 0; i < dim[0]; i++) {\n          arr[i] = init;\n        } \n      }\n    } else if(dim.length > 1) {\n      for(i = 0; i < dim[0]; i++) {\n        arr[i] = create_array(dim.slice(1), init);\n      }\n    } else {\n      throw \"create_array can't create a dimensionless array\";\n    }\n    return arr;\n  };\n  \n  /**\n   * Return the dimensions of a possibly nested array as an array. For \n   * example, array_dim( [[1, 2], [1, 2]] ) should return [2, 2]\n   * Assumes that all arrays inside another array are of the same length.\n   * @example\n   * // Should return [4, 2, 1]\n   * array_dim(create_array([4, 2, 1], 0))\n   */\n  var array_dim = function(a) {\n    if(Array.isArray(a[0])) {\n      return [a.length].concat(array_dim(a[0]));\n    } else {\n      return [a.length];\n    }\n  };\n  \n  /**\n   * Checks if two arrays are equal in the sense that they contain the same elements\n   * as judged by the \"==\" operator. Returns true or false.\n   * Adapted from http://stackoverflow.com/a/14853974/1001848\n   */ \n  var array_equal = function (a1, a2) {\n      if (a1.length != a2.length) return false;\n      for (var i = 0; i < a1.length; i++) {\n          // Check if we have nested arrays\n          if (Array.isArray(a1[i]) && Array.isArray(a2[i])) {\n              // recurse into the nested arrays\n              if (!array_equal(a1[i], a2[i])) return false;       \n          }           \n          else if (a1[i] != a2[i]) { \n              // Warning - two different object instances will never be equal: {x:20} != {x:20}\n              return false;   \n          }           \n      }       \n      return true;\n  };\n  \n  /**\n   * Traverses a possibly nested array a and applies fun to all \"leaf nodes\", \n   * that is, values that are not arrays. Returns an array of the same size as\n   * a.\n   */\n  var nested_array_apply = function(a, fun) {\n    if(Array.isArray(a)) {\n      var result = new Array(a.length);\n      for(var i = 0; i < a.length; i++) {\n        result[i] = nested_array_apply(a[i], fun);\n      }\n      return result;\n    } else {\n      return fun(a);\n    }\n  };\n  \n  /** Randomizing the array element order in-place. Using Durstenfeld\n   * shuffle algorithm. Adapted from here: \n   * http://stackoverflow.com/a/12646864/1001848\n   */\n  function shuffle_array(array) {\n      for (var i = array.length - 1; i > 0; i--) {\n          var j = Math.floor(Math.random() * (i + 1));\n          var temp = array[i];\n          array[i] = array[j];\n          array[j] = temp;\n      }\n      return array;\n  }\n  \n  /**\n   * Does the same thing as nested_array_apply, that is, traverses a possibly\n   * nested array a and applies fun to all \"leaf nodes\" and returns an array \n   * of the same size as a. The difference is that nested_array_random_apply\n   * branches randomly.\n   */\n  var nested_array_random_apply = function(a, fun) {\n    if(Array.isArray(a)) {\n      var len = a.length;\n      var i;\n      var array_is = [];\n      for(i = 0; i < len; i++) {\n        array_is[i] = i;\n      }\n      shuffle_array(array_is);\n      var result = [];\n      \n      for(i = 0; i < len; i++) {\n        var array_i = array_is[i];\n        result[array_i] = nested_array_apply(a[array_i], fun);\n      }\n      return result;\n    } else {\n      return fun(a);\n    }\n  };\n  \n  /**\n   * Allows a pretty way of setting default options where the defults can be\n   * overridden by an options object.\n   *  @param option_name - the name of the option as a string\n   *  @param my_options - an option object that could have option_name \n   *    as a member.\n   * @param defaul_value - defult value that is returned if option_name \n   *   is not defined in my_options.\n   * @example\n   * var my_options = {pi: 3.14159}\n   * var pi = get_option(\"pi\", my_options, 3.14)\n   */\n  // Pretty way of setting default options where the defaults can be overridden\n  // by an options object. For example:\n  // var pi = get_option(\"pi\", my_options, 3.14)\n  var get_option = function(option_name, options, defaul_value) {\n    options = options || {};\n    return options.hasOwnProperty(option_name) && \n           options[option_name] !== undefined  && \n           options[option_name] !== null ? options[option_name] : defaul_value;\n  };\n  \n  /** Version of get_option where the option should be a one or multi-dimensional\n   * array and where the default can be overridden either by a scalar or by an array.\n   * If it's a scalar the that scalar is used to initialize an array with \n   * dim dimensions.\n   * \n   */\n  var get_multidim_option = function(option_name, options, dim, defaul_value) {\n    var value = get_option(option_name, options, defaul_value);\n     if(! Array.isArray(value)) {\n       value = create_array(dim, value);\n     } \n     if(! array_equal( array_dim(value), dim)) {\n       throw \"The option \" + option_name + \" is of dimension [\" + \n             array_dim(value) + \"] but should be [\" + dim + \"].\";\n    }\n     return value;\n  };\n  \n  ////////// Functions for handling parameter objects //////////\n  //////////////////////////////////////////////////////////////\n  \n  /**\n   * Returns a fixed (same every time) number that could be used to initialize\n   * a parameter of a certain type, possibly with lower and upper bounds.\n   * The possile types are \"real\", \"int\", and \"binary\".\n   */\n  var param_init_fixed = function(type, lower, upper) {\n    if(lower > upper) {\n      throw \"Can not initialize parameter where lower bound > upper bound\";\n    }\n    if(type === \"real\") {\n      if(lower === -Infinity && upper === Infinity) {\n        return 0.5;\n      } else if(lower === -Infinity) {\n        return upper - 0.5;\n      } else if(upper === Infinity) {\n        return lower + 0.5;\n      } else if(lower <= upper) {\n        return (lower + upper) / 2;\n      }\n    } else if(type === \"int\") {\n      if(lower === -Infinity && upper === Infinity) {\n        return 1;\n      } else if(lower === -Infinity) {\n        return upper - 1;\n      } else if(upper === Infinity) {\n        return lower + 1;\n      } else if(lower <= upper){\n        return Math.round((lower + upper) / 2);\n      }\n    } else if(type === \"binary\") {\n      return 1;\n    }\n    throw \"Could not initialize parameter of type \" + type + \"[\" + lower + \", \" + upper + \"]\";\n  };\n  \n  /**\n   * Completes params_to_complete, an object containing parameter descriptions, \n   * and initializes non-initialized parameters. This modified version of\n   * params_to_complete is returned as a deep copy and not modified in place.\n   * Initialization is done by supplying a param_init function with signature\n   * function(type, lower, upper) that should return a single number \n   * (like param_init_fixed, for example).\n   * @example\n   * var params = { \"mu\": {\"type\": \"real\"} }\n   * params = complete_params(params);\n   * // params should now be:\n   * //  {\"mu\": { \"type\": \"real\", \"dim\": [1], \"upper\": Infinity,\n   * //           \"lower\": -Infinity, \"init\": 0.5 }}\n   */ \n  var complete_params  = function(params_to_complete, param_init) {\n    var params = deep_clone(params_to_complete);\n    for (var param_name in params) { if (!params.hasOwnProperty(param_name)) continue;\n      var param = params[param_name];\n      if( !param.hasOwnProperty(\"type\")) {\n        param.type = \"real\";\n      }\n      if(!param.hasOwnProperty(\"dim\")) {\n        param.dim = [1];\n      }\n      if(is_number(param.dim)) {\n        param.dim = [param.dim];\n      }\n      if(param.type == \"binary\") {\n        param.upper = 1;\n        param.lower = 0;\n      }\n      if(!param.hasOwnProperty(\"upper\")) {\n        param.upper = Infinity;\n      }\n      if(!param.hasOwnProperty(\"lower\")) {\n        param.lower = -Infinity;\n      }\n      \n      if(param.hasOwnProperty(\"init\")) {\n        // If this is just a number or a nested array we leave it alone, but if...\n        if(array_equal(param.dim, [1]) && typeof param.init === \"function\") {\n          // param.init is a function, use that to initialize the parameter.\n          param.init = param.init();\n        } else if(!array_equal(param.dim, [1]) && !Array.isArray(param.init)) {\n        // We have a multidimensional parameter where the param.init exist but\n        // is not an array. Then assume it is a number or a function and use\n        // it to initialize the parameter.\n        param.init = create_array(param.dim, param.init);\n        }\n      } else { // We use the default initialization function.\n        if(array_equal(param.dim, [1])) {\n          param.init = param_init(param.type, param.lower, param.upper);\n        } else {\n          param.init = create_array(param.dim, function() {\n            return param_init(param.type, param.lower, param.upper);\n          });\n        }\n      }\n    }\n    return params;\n  };\n  \n  \n  ////////// Stepper Functions ///////////\n  ////////////////////////////////////////\n  \n  \n  /**\n   * @interface\n   * A Stepper is an object responsible for pushing around one\n   * or more parameter values in a state according to the distribution\n   * defined by the log posterior. This defines the Stepper \"interface\",\n   * where \"interface\" means that Stepper defines a class that is never\n   * meant to be instantiated, but just to be subclassed by specialized\n   * stepper functions.\n   * @interface\n   * @param params - An object with parameter definitions, for example:\n   *   {\"mu\": { \"type\": \"real\", \"dim\": [1], \"upper\": Infinity, \n   *   \"lower\": -Infinity, \"init\": 0.5 }}\n   *   The parameter definitions are expected to be \"complete\", that is,\n   *   specifying all relevant attributes such as dim, lower and upper.\n   * @param state - an object containing the state of all parameters in params\n   *   (and possibly more). The parameter names are given as keys and the states\n   *   as scalars or, possibly nested, arrays. For example:\n   *   {mu: 10, sigma: 5, beta: [1, 2.5]}\n   * @param log_post - A function *taking no parameters* that returns the\n   *   log density that depends on the state. That is, the value of log_post\n   *   should change if the the values in state are changed.\n  \n   */\n  var Stepper = function(params, state, log_post) {\n    this.params = params;\n    this.state = state;\n    this.log_post = log_post;\n  };\n  \n  /**\n   * Takes a step in the parameter space. Should return the new state,\n   * but is mainly called for it's side effect of making a change in the\n   * state object.\n   */\n  Stepper.prototype.step = function() {\n    throw \"Every Stepper need to implement step()\";\n  };\n  \n  /**\n   * If implemented, makes the stepper adapt while stepping.\n   */ \n  Stepper.prototype.start_adaptation = function() {\n    // Optional, some steppers might not be adaptive. */ \n  };\n  \n  /**\n   * If implemented, makes the stepper cease adapting while stepping.\n   */ \n  Stepper.prototype.stop_adaptation = function() {\n    // Optional, some steppers might not be adaptive. */ \n  };\n  \n  /**\n   * Returns an object containg info regarding the stepper.\n   */ \n  Stepper.prototype.info = function() {\n    // Returns an object with info about the state of the stepper.\n    return {};\n  };\n  \n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements the metropolis step in\n   * the Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008).\n   * @param params - An object with a single parameter definition.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n   * @param generate_proposal - a function returning a proposal (as a number)\n   * with signature function(param_state, log_scale) where param_state is a\n   * number and log_scale defines the scale of the proposal somehow.\n  */\n  var OnedimMetropolisStepper = function(params, state, log_post, options, generate_proposal) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  != 1) {\n      throw \"OnedimMetropolisStepper can only handle one parameter.\";\n    }\n    this.param_name = param_names[0];\n    var param = this.params[this.param_name];\n    if(!array_equal(param.dim, [1])) {\n      throw \"OnedimMetropolisStepper can only handle one one-dimensional parameter.\";\n    }\n    this.lower = param.lower;\n    this.upper = param.upper;\n    \n    this.prop_log_scale     = get_option(\"prop_log_scale\", options, 0);\n    this.batch_size         = get_option(\"batch_size\", options, 50);\n    this.max_adaptation     = get_option(\"max_adaptation\", options, 0.33);\n    this.initial_adaptation = get_option(\"initial_adaptation\", options, 1.0);\n    this.target_accept_rate = get_option(\"target_accept_rate\", options, 0.44);\n    this.is_adapting        = get_option(\"is_adapting\", options, true);\n    \n    this.generate_proposal = generate_proposal;\n    \n    this.acceptance_count = 0;\n    this.batch_count = 0;\n    this.iterations_since_adaption = 0;  \n  };\n  \n  OnedimMetropolisStepper.prototype = Object.create(Stepper.prototype); \n  OnedimMetropolisStepper.prototype.constructor = OnedimMetropolisStepper;\n  \n  OnedimMetropolisStepper.prototype.step = function() {\n      var param_state = this.state[this.param_name];\n      var param_proposal = this.generate_proposal(param_state, this.prop_log_scale);\n      if(param_proposal < this.lower || param_proposal > this.upper) {\n        // Outside of limits of the parameter, reject the proposal \n        // and stay at the current state.\n      } else { // make a Metropolis step\n        var curr_log_dens = this.log_post();\n        this.state[this.param_name] = param_proposal;\n        var prop_log_dens = this.log_post();\n        var accept_prob = Math.exp(prop_log_dens - curr_log_dens);\n        if(accept_prob > Math.random()) {\n          // We do nothing as the state of param has already been changed to the proposal\n          if(this.is_adapting) this.acceptance_count++ ;\n        } else {\n          // revert state back to the old state of param\n          this.state[this.param_name] = param_state;\n        }\n      }\n      if(this.is_adapting) {\n        this.iterations_since_adaption ++;\n        if(this.iterations_since_adaption >= this.batch_size) { // then adapt\n          this.batch_count ++;\n          var log_sd_adjustment = \n            Math.min(this.max_adaptation, \n                     this.initial_adaptation / Math.sqrt(this.batch_count));\n          if(this.acceptance_count / this.batch_size > this.target_accept_rate) {\n            this.prop_log_scale += log_sd_adjustment;\n          } else {\n            this.prop_log_scale -= log_sd_adjustment;\n          }\n          this.acceptance_count = 0;\n          this.iterations_since_adaption = 0;\n        }\n      }\n      return this.state[this.param_name];\n  };\n  \n  OnedimMetropolisStepper.prototype.start_adaptation = function() {\n    this.is_adapting = true;\n  };\n  \n  OnedimMetropolisStepper.prototype.stop_adaptation = function() {\n    this.is_adapting = false;\n  };\n  \n  OnedimMetropolisStepper.prototype.info = function() {\n    return {\n      prop_log_scale: this.prop_log_scale,\n      is_adapting: this.is_adapting,\n      acceptance_count: this.acceptance_count,\n      iterations_since_adaption: this.iterations_since_adaption,\n      batch_count: this.batch_count\n    };\n  };\n  \n  \n  /**\n   * Function returning a Normal proposal.\n   */\n  var normal_proposal = function(param_state, prop_log_scale) {\n    return rnorm(param_state , Math.exp(prop_log_scale));\n  };\n  \n  /**\n   * @class\n   * @augments {OnedimMetropolisStepper}\n   * A \"subclass\" of OnedimMetropolisStepper making continous Normal proposals.\n   */\n  var RealMetropolisStepper = function(params, state, log_post, options) {\n    OnedimMetropolisStepper.call(this, params, state, log_post, options, normal_proposal);\n  };\n  \n  RealMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype); \n  RealMetropolisStepper.prototype.constructor = RealMetropolisStepper;\n  \n  /**\n   * Function returning a discretized Normal proposal.\n   */\n  var discrete_normal_proposal = function(param_state, prop_log_scale) {\n    return Math.round(rnorm(param_state , Math.exp(prop_log_scale)));\n  };\n  \n    /**\n   * @class\n   * @augments {OnedimMetropolisStepper}\n   * A \"subclass\" of OnedimMetropolisStepper making discretized Normal proposals.\n   */\n  var IntMetropolisStepper = function(params, state, log_post, options) {\n    OnedimMetropolisStepper.call(this, params, state, log_post, options, discrete_normal_proposal);\n  };\n  \n  IntMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype); \n  IntMetropolisStepper.prototype.constructor = IntMetropolisStepper;\n  \n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements the metropolis step in\n   * the Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008) for possibly multidimensional arrays. That\n   * is, instead of just taking a step for a one-dimensional parameter like \n   * OnedimMetropolisStepper, this Stepper is responsible for taking steps \n   * for a multidimensional array. It's still pretty dumb and just takes\n   * one-dimensional steps for each parameter component, though.\n   * @param params - An object with a single parameter definition for a \n   *   multidimensional parameter.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n   * @param SubStepper - a constructor for the type of one dimensional Stepper to apply on\n   *   all the components of the multidimensional parameter.\n  */\n  var MultidimComponentMetropolisStepper = function(params, state, log_post, options, SubStepper) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  != 1) {\n      throw \"MultidimComponentMetropolisStepper can't handle more than one parameter.\";\n    }\n    this.param_name = param_names[0];\n    var param = this.params[this.param_name];\n    this.lower = param.lower;\n    this.upper = param.upper;\n    this.dim = param.dim;\n  \n    this.prop_log_scale     = get_multidim_option(\"prop_log_scale\", options, this.dim, 0);\n    this.batch_size         = get_multidim_option(\"batch_size\", options, this.dim, 50);\n    this.max_adaptation     = get_multidim_option(\"max_adaptation\", options, this.dim, 0.33);\n    this.initial_adaptation = get_multidim_option(\"initial_adaptation\", options, this.dim, 1.0);\n    this.target_accept_rate = get_multidim_option(\"target_accept_rate\", options, this.dim, 0.44);\n    this.is_adapting        = get_multidim_option(\"is_adapting\", options, this.dim, true);\n    \n    // This hack below is a recursive function that creates an array of \n    // one dimensional steppers according to dim.\n    var create_substeppers = \n      function(dim, substate, log_post, prop_log_scale, batch_size, max_adaptation, initial_adaptation, target_accept_rate, is_adapting) {\n      var substeppers = [];\n      if(dim.length === 1) {\n        for(var i = 0; i < dim[0]; i++) {\n          var suboptions = {prop_log_scale: prop_log_scale[i], batch_size: batch_size[i],\n            max_adaptation: max_adaptation[i], initial_adaptation: initial_adaptation[i],\n            target_accept_rate: target_accept_rate[i], is_adapting: is_adapting[i]};\n            var subparam = {};\n            subparam[i] = deep_clone(param);\n            subparam[i].dim = [1]; // As this should now be a one-dim parameter\n            delete subparam[i].init; // As it sould not be needed\n          substeppers[i] = new SubStepper(subparam, substate, log_post, suboptions);\n        }\n      } else {\n        for(var i = 0; i < dim[0]; i++) {\n          substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post, prop_log_scale[i], \n            batch_size[i], max_adaptation[i], initial_adaptation[i], target_accept_rate[i], is_adapting[i]);\n        }\n      }\n      return substeppers;\n    };\n    \n    this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post,\n      this.prop_log_scale, this.batch_size, this.max_adaptation, this.initial_adaptation,\n      this.target_accept_rate, this.is_adapting);\n    \n  };\n  \n  MultidimComponentMetropolisStepper.prototype = Object.create(Stepper.prototype); \n  MultidimComponentMetropolisStepper.prototype.constructor = MultidimComponentMetropolisStepper;\n  \n  MultidimComponentMetropolisStepper.prototype.step = function() {\n    // Go through the substeppers in a random order and call step() on them.\n    return nested_array_random_apply(this.substeppers, function(substepper) {return substepper.step(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.start_adaptation = function() {\n    nested_array_apply(this.substeppers, function(substepper) {substepper.start_adaptation(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.stop_adaptation = function() {\n    nested_array_apply(this.substeppers, function(substepper) {substepper.stop_adaptation(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.info = function() {\n    return nested_array_apply(this.substeppers, function(substepper) {\n      return substepper.info(); \n    });\n  };\n  \n  /**\n   * @class\n   * @augments {MultidimComponentMetropolisStepper}\n   * A \"subclass\" of MultidimComponentMetropolisStepper making continous Normal proposals.\n   */\n  var MultiRealComponentMetropolisStepper = function(params, state, log_post, options) {\n    MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, RealMetropolisStepper);\n  };\n  \n  MultiRealComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype); \n  MultiRealComponentMetropolisStepper.prototype.constructor = MultiRealComponentMetropolisStepper;\n\n  /**\n   * @class\n   * @augments {MultidimComponentMetropolisStepper}\n   * A \"subclass\" of MultidimComponentMetropolisStepper making discretized Normal proposals.\n   */    \n  var MultiIntComponentMetropolisStepper = function(params, state, log_post, options) {\n    MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, IntMetropolisStepper);\n  };\n  \n  MultiIntComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype); \n  MultiIntComponentMetropolisStepper.prototype.constructor = MultiIntComponentMetropolisStepper;\n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements a step for a binary parameter.\n   * This is done by evaluating the log posterior for both states of the\n   * parameter and then selecting a state randomly with probability relative \n   * to the posterior of each state.\n   * @param params - An object with a single parameter definition.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var BinaryStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    var param_names = Object.keys(this.params);\n    if(param_names.length  == 1) {\n      this.param_name = param_names[0];\n    } else {\n      throw \"BinaryStepper can't handle more than one parameter.\";\n    }\n  };\n  \n  BinaryStepper.prototype = Object.create(Stepper.prototype); \n  BinaryStepper.prototype.constructor = BinaryStepper;\n  \n  BinaryStepper.prototype.step = function() {\n    this.state[this.param_name] = 0;\n    var zero_log_dens = this.log_post();\n    this.state[this.param_name] = 1;\n    var one_log_dens = this.log_post();\n    var max_log_dens = Math.max(zero_log_dens, one_log_dens);\n    zero_log_dens -= max_log_dens;\n    one_log_dens -= max_log_dens;\n    var zero_prob = Math.exp(zero_log_dens - Math.log( Math.exp(zero_log_dens) + Math.exp(one_log_dens) ) );\n    if(Math.random() < zero_prob) {\n      this.state[this.param_name] = 0;\n      return 0;\n    } // else keep the param at 1 .\n    return 1;\n  };\n  \n    /**\n   * @class\n   * @implements {Stepper}\n   * Just like MultidimComponentMetropolisStepper this Stepper takes a steps for\n   * a multidimensional parameter by updating each component in turn. The difference\n   * is that this stepper works on binary parameters.\n   * @param params - An object with a single parameter definition for a \n   *   multidimensional parameter.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var BinaryComponentStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  == 1) {\n      this.param_name = param_names[0];\n      var param = this.params[this.param_name];\n      this.dim = param.dim;\n    } else {\n      throw \"BinaryComponentStepper can't handle more than one parameter.\";\n    }\n    \n    var create_substeppers = \n      function(dim, substate, log_post) {\n      var substeppers = [];\n      var i;\n      if(dim.length === 1) {\n        for(i = 0; i < dim[0]; i++) {\n          var subparams = {};\n          subparams[i] = param;\n          substeppers[i] = new BinaryStepper(subparams, substate, log_post);\n        }\n      } else {\n        for(i = 0; i < dim[0]; i++) {\n          substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post);\n        }\n      }\n      return substeppers;\n    };\n    \n    this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post);\n  };\n  \n  BinaryComponentStepper.prototype = Object.create(Stepper.prototype); \n  BinaryComponentStepper.prototype.constructor = BinaryComponentStepper;\n  \n  BinaryComponentStepper.prototype.step = function() {\n    // Go through the substeppers in a random order and call step() on them.\n    return nested_array_random_apply(this.substeppers, function(substepper) {return substepper.step(); });\n  };\n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * This stepper can be responsible for taking a step for one or more parameters.\n   * For real and int parameters it takes Metropolis within Gibbs steps, and for \n   * binary parameters it does evaluates the posterior for both paramter values and\n   * randomly changes to a certain value proportionally to that value's posterior\n   * (this is also done for each parameter, so also a * within Gibbs approach).\n   * This stepper is also adaptive and can be efficient when the number of parameters\n   * are not too high and the correlations between parameters are low.\n   * @param params - An object with a one or more parameter definitions\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var AmwgStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    this.param_names = Object.keys(this.params);\n    this.substeppers = [];\n    for(var i = 0; i < this.param_names.length; i++) {\n      var param = params[this.param_names[i]];\n      var SelectStepper;\n      switch (param.type) {\n        case \"real\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = RealMetropolisStepper;\n          } else {\n            SelectStepper = MultiRealComponentMetropolisStepper;\n          }\n          break;\n        case \"int\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = IntMetropolisStepper;\n          } else {\n            SelectStepper = MultiIntComponentMetropolisStepper;\n          }\n          break;\n        case \"binary\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = BinaryStepper;\n          } else {\n            SelectStepper = BinaryComponentStepper;\n          }\n          break;\n        default:\n          throw \"AmwgStepper can't handle parameter \" + this.param_names[i]  +\" with type \" + param.type; \n      }\n      var param_object_wrap = {};\n      param_object_wrap[this.param_names[i]] = param;\n      options = options || {};\n      var param_options = options.params && options.params[this.param_names[i]] || {};\n      param_options.prop_log_scale     = param_options.prop_log_scale     || options.prop_log_scale; \n      param_options.batch_size         = param_options.batch_size         || options.batch_size; \n      param_options.max_adaptation     = param_options.max_adaptation     || options.max_adaptation;\n      param_options.initial_adaptation = param_options.initial_adaptation || options.initial_adaptation;\n      param_options.target_accept_rate = param_options.target_accept_rate || options.target_accept_rate; \n      param_options.is_adapting        = param_options.is_adapting        || options.is_adapting; \n      this.substeppers[i] = new SelectStepper(param_object_wrap, state, log_post, param_options);\n    }\n  };\n  \n  AmwgStepper.prototype = Object.create(Stepper.prototype); \n  AmwgStepper.prototype.constructor = AmwgStepper;\n  \n  AmwgStepper.prototype.step = function() {\n    shuffle_array(this.substeppers);\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].step();\n    }\n    return this.state;\n  };\n  \n  AmwgStepper.prototype.start_adaptation = function() {\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].start_adaptation();\n    }\n  };\n  \n  AmwgStepper.prototype.stop_adaptation = function() {\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].stop_adaptation();\n    } \n  };\n  \n  AmwgStepper.prototype.info = function() {\n    var info = {};\n    for(var i = 0; i < this.substeppers.length; i++) {\n      info[this.param_names[i]] = this.substeppers[i].info();\n    }\n    return info;\n  };\n  \n  \n  \n  /////////// Sampler Functions //////////\n  ////////////////////////////////////////\n  \n  \n   /**\n   * @interface\n   * While you could fit a model by pasting together Steppers, a\n  // Sampler is here is a convenience class where an instance of Sampler\n  // sets up the Steppers, checks the parameter definition,\n  // and manages the sampling. This here defines the Sampler \"interface\".\n   * @interface\n   * @param params - An object with parameter definitions, for example:\n   *   {\"mu\": {\"type\": \"real\"}, \"sigma\": {\"type\": \"real\", \"lower\" = 0}}\n   *   The parameter definitions doesn't have to be \"complete\" and properties\n   *   left out (like lower and upper) will be filled in by defaults.\n   * @param log_post - A function with signature function(state, data). Here\n   *   state will be an object representing the state with each parameter as a \n   *   key and the parameter values as numbers or arrays. For example:\n   *   {\"mu\": 3, \"sigma\": 1.5}. The data argument will be the same object as \n   *   the data argument given below.\n   * @param data - an object that will be passed on to the log_post function\n   *   when sampling.\n   * @param options - an object with options to the sampler.\n   */\n  var Sampler = function(params, log_post, data, options) {\n    this.params = params;\n    this.data = data;\n    this.param_names = Object.keys(this.params);\n    \n    // Setting default options if not passed through the options object\n    this.param_init_fun   = get_option(\"param_init_fun\", options, param_init_fixed);\n    var thinning_interval = get_option(\"thin\", options, 1);\n    var params_to_monitor = get_option(\"monitor\", options, null);\n    this.thin(thinning_interval);\n    this.monitor(params_to_monitor);\n    this.options = options;\n    // Completing the params and initializing the state.\n    this.params = complete_params(this.params, this.param_init_fun);\n    var state = {};\n    for(var i = 0; i < this.param_names.length; i++ ) {\n      state[this.param_names[i]] = this.params[this.param_names[i]].init;\n    }\n    this.log_post = function() { \n      return log_post(state, data);\n    };\n    // Running the log_post function once in case it further modifies the state\n    // for example adding derived quantities.\n    this.log_post();\n    this.state = state;\n    this.steppers = this.create_stepper_ensamble(this.params, this.state, this.log_post, this.options);\n  };\n  \n  /** Should return a vector of steppers that when called \n   * should take a step in the parameter space.\n   */\n  Sampler.prototype.create_stepper_ensamble = function(state, log_post){\n    throw \"Every Sampler needs to implement create_stepper_ensamble()\";\n  };\n  \n  /** Returns an object with info about the state of the Sampler.\n   */ \n  Sampler.prototype.info = function() {\n    return {state: this.state, thin: this.thin, monitor: this.monitor,\n            steppers: this.steppers};\n  };\n  \n  /** Takes a step in the parameter space. Returns the new space\n   * but also modifies the state in place.\n   */ \n  Sampler.prototype.step = function() {\n    shuffle_array(this.steppers);\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].step();\n    }\n    if(Object.keys(this.state).length > Object.keys(this.params).length) {\n      // The state contains devived quantities (not only parameters) and we\n      // need to run the log_post once more in order to set the derived quantities\n      // for the final parameter state\n      this.log_post();\n    }\n    return this.state;\n  };\n  \n  /**\n   * Takes n_iterations steps in the parameter space and returns them\n   * as an object of arrays with one array per parameter. For example:\n   * {mu: [1, -1, 2, 3, ...], sigma: [1, 2, 2, 1, ...]}.\n   * If thin is > 1 then n_iterations / thin samples are returned.\n   */ \n  Sampler.prototype.sample = function(n_iterations) {\n      // Initializing curr_sample where the sample is going to be saved\n      // as an object containing one array per parameter to be monitored.\n      var i, j, monitored_params;\n      if(this.monitored_params === null) {\n        monitored_params = Object.keys(this.state);\n      } else {\n        monitored_params = this.monitored_params;\n      }\n      \n      var curr_sample = {};\n      for(j = 0; j < monitored_params.length; j++) {\n        curr_sample[monitored_params[j]] = [];\n      }\n      \n      for(i = 0; i < n_iterations; i++) {\n        if(i % this.thinning_interval === 0) {\n          for(j = 0; j < monitored_params.length; j++) {\n            var param = monitored_params[j];\n            curr_sample[param].push( clone_param_draw(this.state[param]) );\n          }\n        }\n        this.step();\n      }\n      return curr_sample;\n  };\n  \n  /**\n   * Takes n_iteration steps in parameter space but returns nothing.\n   */ \n  Sampler.prototype.burn = function(n_iterations) {\n    for(var i = 0; i < n_iterations; i++) {\n      this.step();\n    }\n  };\n  \n  /**\n   * Sets what parameters should be monitored and returned when calling\n   * sample.\n   */ \n  Sampler.prototype.monitor = function(params_to_monitor) {\n      this.monitored_params = params_to_monitor;\n  };\n  \n  /**\n   * Sets the thinning. For example thin == 10 means that every 10th posterior\n   * draw will be kept.\n   */ \n  Sampler.prototype.thin = function(thinning_interval) {\n    this.thinning_interval = thinning_interval;\n  };\n  \n  /**\n   * Sets adaptation on, if applicable, in all steppers.\n   */ \n  Sampler.prototype.start_adaptation = function() {\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].start_adaptation();\n    }\n  };\n  \n    /**\n   * Sets adaptation off, if applicable, in all steppers.\n   */ \n  Sampler.prototype.stop_adaptation = function() {\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].stop_adaptation();\n    }\n  };\n  \n   /**\n   * @class\n   * @implements {Sampler}\n   * This sampler uses the AmwgStepper as the stepper function which implements the \n   * Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008). An adition is that it handles int parameters\n   * by making discrete Normal proposals and binary parameters by taking on a new \n   * value proportional to the posterior of the two possible states of the\n   * parameter. This sampler can be efficient when the number of parameters\n   * are not too high and the correlations between parameters are low.\n   * @param params - An object with a one or more parameter definitions\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var AmwgSampler = function(params, log_post, data, options) {\n    Sampler.call(this, params, log_post, data, options);\n  };\n  \n  AmwgSampler.prototype = Object.create(Sampler.prototype); \n  AmwgSampler.prototype.constructor = AmwgSampler;\n  \n  AmwgSampler.prototype.create_stepper_ensamble = function(params, state, log_post, options){\n    return [ new AmwgStepper(params, state, log_post, options) ];\n  };\n  \n  \n  // Returning the functions that should be publicly exposed by this module\n  return {\n    runif: runif,\n    runif_discrete: runif_discrete,\n    rnorm: rnorm,\n    param_init_fixed: param_init_fixed, \n    complete_params: complete_params, \n    RealMetropolisStepper: RealMetropolisStepper, \n    IntMetropolisStepper: IntMetropolisStepper, \n    MultiRealComponentMetropolisStepper: MultiRealComponentMetropolisStepper, \n    MultiIntComponentMetropolisStepper: MultiIntComponentMetropolisStepper, \n    BinaryStepper: BinaryStepper, \n    BinaryComponentStepper: BinaryComponentStepper, \n    AmwgStepper: AmwgStepper, \n    AmwgSampler: AmwgSampler\n  };\n}));\n","export default function ascending(a, b) {\n  return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","export default function number(x) {\n  return x === null ? NaN : +x;\n}\n\nexport function* numbers(values, valueof) {\n  if (valueof === undefined) {\n    for (let value of values) {\n      if (value != null && (value = +value) >= value) {\n        yield value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n        yield value;\n      }\n    }\n  }\n}\n","import ascending from \"./ascending.js\";\nimport permute from \"./permute.js\";\n\nexport default function sort(values, ...F) {\n  if (typeof values[Symbol.iterator] !== \"function\") throw new TypeError(\"values is not iterable\");\n  values = Array.from(values);\n  let [f] = F;\n  if ((f && f.length !== 2) || F.length > 1) {\n    const index = Uint32Array.from(values, (d, i) => i);\n    if (F.length > 1) {\n      F = F.map(f => values.map(f));\n      index.sort((i, j) => {\n        for (const f of F) {\n          const c = ascendingDefined(f[i], f[j]);\n          if (c) return c;\n        }\n      });\n    } else {\n      f = values.map(f);\n      index.sort((i, j) => ascendingDefined(f[i], f[j]));\n    }\n    return permute(values, index);\n  }\n  return values.sort(compareDefined(f));\n}\n\nexport function compareDefined(compare = ascending) {\n  if (compare === ascending) return ascendingDefined;\n  if (typeof compare !== \"function\") throw new TypeError(\"compare is not a function\");\n  return (a, b) => {\n    const x = compare(a, b);\n    if (x || x === 0) return x;\n    return (compare(b, b) === 0) - (compare(a, a) === 0);\n  };\n}\n\nexport function ascendingDefined(a, b) {\n  return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);\n}\n","export default function max(values, valueof) {\n  let max;\n  if (valueof === undefined) {\n    for (const value of values) {\n      if (value != null\n          && (max < value || (max === undefined && value >= value))) {\n        max = value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null\n          && (max < value || (max === undefined && value >= value))) {\n        max = value;\n      }\n    }\n  }\n  return max;\n}\n","export default function min(values, valueof) {\n  let min;\n  if (valueof === undefined) {\n    for (const value of values) {\n      if (value != null\n          && (min > value || (min === undefined && value >= value))) {\n        min = value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null\n          && (min > value || (min === undefined && value >= value))) {\n        min = value;\n      }\n    }\n  }\n  return min;\n}\n","import {ascendingDefined, compareDefined} from \"./sort.js\";\n\n// Based on https://github.com/mourner/quickselect\n// ISC license, Copyright 2018 Vladimir Agafonkin.\nexport default function quickselect(array, k, left = 0, right = Infinity, compare) {\n  k = Math.floor(k);\n  left = Math.floor(Math.max(0, left));\n  right = Math.floor(Math.min(array.length - 1, right));\n\n  if (!(left <= k && k <= right)) return array;\n\n  compare = compare === undefined ? ascendingDefined : compareDefined(compare);\n\n  while (right > left) {\n    if (right - left > 600) {\n      const n = right - left + 1;\n      const m = k - left + 1;\n      const z = Math.log(n);\n      const s = 0.5 * Math.exp(2 * z / 3);\n      const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n      const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n      const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n      quickselect(array, k, newLeft, newRight, compare);\n    }\n\n    const t = array[k];\n    let i = left;\n    let j = right;\n\n    swap(array, left, k);\n    if (compare(array[right], t) > 0) swap(array, left, right);\n\n    while (i < j) {\n      swap(array, i, j), ++i, --j;\n      while (compare(array[i], t) < 0) ++i;\n      while (compare(array[j], t) > 0) --j;\n    }\n\n    if (compare(array[left], t) === 0) swap(array, left, j);\n    else ++j, swap(array, j, right);\n\n    if (j <= k) left = j + 1;\n    if (k <= j) right = j - 1;\n  }\n\n  return array;\n}\n\nfunction swap(array, i, j) {\n  const t = array[i];\n  array[i] = array[j];\n  array[j] = t;\n}\n","import max from \"./max.js\";\nimport maxIndex from \"./maxIndex.js\";\nimport min from \"./min.js\";\nimport minIndex from \"./minIndex.js\";\nimport quickselect from \"./quickselect.js\";\nimport number, {numbers} from \"./number.js\";\nimport {ascendingDefined} from \"./sort.js\";\nimport greatest from \"./greatest.js\";\n\nexport default function quantile(values, p, valueof) {\n  values = Float64Array.from(numbers(values, valueof));\n  if (!(n = values.length) || isNaN(p = +p)) return;\n  if (p <= 0 || n < 2) return min(values);\n  if (p >= 1) return max(values);\n  var n,\n      i = (n - 1) * p,\n      i0 = Math.floor(i),\n      value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),\n      value1 = min(values.subarray(i0 + 1));\n  return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileSorted(values, p, valueof = number) {\n  if (!(n = values.length) || isNaN(p = +p)) return;\n  if (p <= 0 || n < 2) return +valueof(values[0], 0, values);\n  if (p >= 1) return +valueof(values[n - 1], n - 1, values);\n  var n,\n      i = (n - 1) * p,\n      i0 = Math.floor(i),\n      value0 = +valueof(values[i0], i0, values),\n      value1 = +valueof(values[i0 + 1], i0 + 1, values);\n  return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileIndex(values, p, valueof = number) {\n  if (isNaN(p = +p)) return;\n  numbers = Float64Array.from(values, (_, i) => number(valueof(values[i], i, values)));\n  if (p <= 0) return minIndex(numbers);\n  if (p >= 1) return maxIndex(numbers);\n  var numbers,\n      index = Uint32Array.from(values, (_, i) => i),\n      j = numbers.length - 1,\n      i = Math.floor(j * p);\n  quickselect(index, i, 0, j, (i, j) => ascendingDefined(numbers[i], numbers[j]));\n  i = greatest(index.subarray(0, i + 1), (i) => numbers[i]);\n  return i >= 0 ? i : -1;\n}\n","import quantile, {quantileIndex} from \"./quantile.js\";\n\nexport default function median(values, valueof) {\n  return quantile(values, 0.5, valueof);\n}\n\nexport function medianIndex(values, valueof) {\n  return quantileIndex(values, 0.5, valueof);\n}\n","var noop = {value: () => {}};\n\nfunction dispatch() {\n  for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n    if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n    _[t] = [];\n  }\n  return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n  this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n    return {type: t, name: name};\n  });\n}\n\nDispatch.prototype = dispatch.prototype = {\n  constructor: Dispatch,\n  on: function(typename, callback) {\n    var _ = this._,\n        T = parseTypenames(typename + \"\", _),\n        t,\n        i = -1,\n        n = T.length;\n\n    // If no callback was specified, return the callback of the given type and name.\n    if (arguments.length < 2) {\n      while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n      return;\n    }\n\n    // If a type was specified, set the callback for the given type and name.\n    // Otherwise, if a null callback was specified, remove callbacks of the given name.\n    if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n    while (++i < n) {\n      if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n      else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n    }\n\n    return this;\n  },\n  copy: function() {\n    var copy = {}, _ = this._;\n    for (var t in _) copy[t] = _[t].slice();\n    return new Dispatch(copy);\n  },\n  call: function(type, that) {\n    if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  },\n  apply: function(type, that, args) {\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  }\n};\n\nfunction get(type, name) {\n  for (var i = 0, n = type.length, c; i < n; ++i) {\n    if ((c = type[i]).name === name) {\n      return c.value;\n    }\n  }\n}\n\nfunction set(type, name, callback) {\n  for (var i = 0, n = type.length; i < n; ++i) {\n    if (type[i].name === name) {\n      type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n      break;\n    }\n  }\n  if (callback != null) type.push({name: name, value: callback});\n  return type;\n}\n\nexport default dispatch;\n","export var xhtml = \"http://www.w3.org/1999/xhtml\";\n\nexport default {\n  svg: \"http://www.w3.org/2000/svg\",\n  xhtml: xhtml,\n  xlink: \"http://www.w3.org/1999/xlink\",\n  xml: \"http://www.w3.org/XML/1998/namespace\",\n  xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\n","import namespaces from \"./namespaces.js\";\n\nexport default function(name) {\n  var prefix = name += \"\", i = prefix.indexOf(\":\");\n  if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n  return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name; // eslint-disable-line no-prototype-builtins\n}\n","import namespace from \"./namespace.js\";\nimport {xhtml} from \"./namespaces.js\";\n\nfunction creatorInherit(name) {\n  return function() {\n    var document = this.ownerDocument,\n        uri = this.namespaceURI;\n    return uri === xhtml && document.documentElement.namespaceURI === xhtml\n        ? document.createElement(name)\n        : document.createElementNS(uri, name);\n  };\n}\n\nfunction creatorFixed(fullname) {\n  return function() {\n    return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n  };\n}\n\nexport default function(name) {\n  var fullname = namespace(name);\n  return (fullname.local\n      ? creatorFixed\n      : creatorInherit)(fullname);\n}\n","function none() {}\n\nexport default function(selector) {\n  return selector == null ? none : function() {\n    return this.querySelector(selector);\n  };\n}\n","import {Selection} from \"./index.js\";\nimport selector from \"../selector.js\";\n\nexport default function(select) {\n  if (typeof select !== \"function\") select = selector(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n}\n","// Given something array like (or null), returns something that is strictly an\n// array. This is used to ensure that array-like objects passed to d3.selectAll\n// or selection.selectAll are converted into proper arrays when creating a\n// selection; we don’t ever want to create a selection backed by a live\n// HTMLCollection or NodeList. However, note that selection.selectAll will use a\n// static NodeList as a group, since it safely derived from querySelectorAll.\nexport default function array(x) {\n  return x == null ? [] : Array.isArray(x) ? x : Array.from(x);\n}\n","function empty() {\n  return [];\n}\n\nexport default function(selector) {\n  return selector == null ? empty : function() {\n    return this.querySelectorAll(selector);\n  };\n}\n","import {Selection} from \"./index.js\";\nimport array from \"../array.js\";\nimport selectorAll from \"../selectorAll.js\";\n\nfunction arrayAll(select) {\n  return function() {\n    return array(select.apply(this, arguments));\n  };\n}\n\nexport default function(select) {\n  if (typeof select === \"function\") select = arrayAll(select);\n  else select = selectorAll(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        subgroups.push(select.call(node, node.__data__, i, group));\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, parents);\n}\n","export default function(selector) {\n  return function() {\n    return this.matches(selector);\n  };\n}\n\nexport function childMatcher(selector) {\n  return function(node) {\n    return node.matches(selector);\n  };\n}\n\n","import {childMatcher} from \"../matcher.js\";\n\nvar find = Array.prototype.find;\n\nfunction childFind(match) {\n  return function() {\n    return find.call(this.children, match);\n  };\n}\n\nfunction childFirst() {\n  return this.firstElementChild;\n}\n\nexport default function(match) {\n  return this.select(match == null ? childFirst\n      : childFind(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","import {childMatcher} from \"../matcher.js\";\n\nvar filter = Array.prototype.filter;\n\nfunction children() {\n  return Array.from(this.children);\n}\n\nfunction childrenFilter(match) {\n  return function() {\n    return filter.call(this.children, match);\n  };\n}\n\nexport default function(match) {\n  return this.selectAll(match == null ? children\n      : childrenFilter(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","import {Selection} from \"./index.js\";\nimport matcher from \"../matcher.js\";\n\nexport default function(match) {\n  if (typeof match !== \"function\") match = matcher(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n}\n","export default function(update) {\n  return new Array(update.length);\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n  return new Selection(this._enter || this._groups.map(sparse), this._parents);\n}\n\nexport function EnterNode(parent, datum) {\n  this.ownerDocument = parent.ownerDocument;\n  this.namespaceURI = parent.namespaceURI;\n  this._next = null;\n  this._parent = parent;\n  this.__data__ = datum;\n}\n\nEnterNode.prototype = {\n  constructor: EnterNode,\n  appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n  insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n  querySelector: function(selector) { return this._parent.querySelector(selector); },\n  querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n};\n","export default function(x) {\n  return function() {\n    return x;\n  };\n}\n","import {Selection} from \"./index.js\";\nimport {EnterNode} from \"./enter.js\";\nimport constant from \"../constant.js\";\n\nfunction bindIndex(parent, group, enter, update, exit, data) {\n  var i = 0,\n      node,\n      groupLength = group.length,\n      dataLength = data.length;\n\n  // Put any non-null nodes that fit into update.\n  // Put any null nodes into enter.\n  // Put any remaining data into enter.\n  for (; i < dataLength; ++i) {\n    if (node = group[i]) {\n      node.__data__ = data[i];\n      update[i] = node;\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Put any non-null nodes that don’t fit into exit.\n  for (; i < groupLength; ++i) {\n    if (node = group[i]) {\n      exit[i] = node;\n    }\n  }\n}\n\nfunction bindKey(parent, group, enter, update, exit, data, key) {\n  var i,\n      node,\n      nodeByKeyValue = new Map,\n      groupLength = group.length,\n      dataLength = data.length,\n      keyValues = new Array(groupLength),\n      keyValue;\n\n  // Compute the key for each node.\n  // If multiple nodes have the same key, the duplicates are added to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if (node = group[i]) {\n      keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + \"\";\n      if (nodeByKeyValue.has(keyValue)) {\n        exit[i] = node;\n      } else {\n        nodeByKeyValue.set(keyValue, node);\n      }\n    }\n  }\n\n  // Compute the key for each datum.\n  // If there a node associated with this key, join and add it to update.\n  // If there is not (or the key is a duplicate), add it to enter.\n  for (i = 0; i < dataLength; ++i) {\n    keyValue = key.call(parent, data[i], i, data) + \"\";\n    if (node = nodeByKeyValue.get(keyValue)) {\n      update[i] = node;\n      node.__data__ = data[i];\n      nodeByKeyValue.delete(keyValue);\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Add any remaining nodes that were not bound to data to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if ((node = group[i]) && (nodeByKeyValue.get(keyValues[i]) === node)) {\n      exit[i] = node;\n    }\n  }\n}\n\nfunction datum(node) {\n  return node.__data__;\n}\n\nexport default function(value, key) {\n  if (!arguments.length) return Array.from(this, datum);\n\n  var bind = key ? bindKey : bindIndex,\n      parents = this._parents,\n      groups = this._groups;\n\n  if (typeof value !== \"function\") value = constant(value);\n\n  for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n    var parent = parents[j],\n        group = groups[j],\n        groupLength = group.length,\n        data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),\n        dataLength = data.length,\n        enterGroup = enter[j] = new Array(dataLength),\n        updateGroup = update[j] = new Array(dataLength),\n        exitGroup = exit[j] = new Array(groupLength);\n\n    bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n    // Now connect the enter nodes to their following update node, such that\n    // appendChild can insert the materialized enter node before this node,\n    // rather than at the end of the parent node.\n    for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n      if (previous = enterGroup[i0]) {\n        if (i0 >= i1) i1 = i0 + 1;\n        while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n        previous._next = next || null;\n      }\n    }\n  }\n\n  update = new Selection(update, parents);\n  update._enter = enter;\n  update._exit = exit;\n  return update;\n}\n\n// Given some data, this returns an array-like view of it: an object that\n// exposes a length property and allows numeric indexing. Note that unlike\n// selectAll, this isn’t worried about “live” collections because the resulting\n// array will only be used briefly while data is being bound. (It is possible to\n// cause the data to change while iterating by using a key function, but please\n// don’t; we’d rather avoid a gratuitous copy.)\nfunction arraylike(data) {\n  return typeof data === \"object\" && \"length\" in data\n    ? data // Array, TypedArray, NodeList, array-like\n    : Array.from(data); // Map, Set, iterable, string, or anything else\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n  return new Selection(this._exit || this._groups.map(sparse), this._parents);\n}\n","export default function(onenter, onupdate, onexit) {\n  var enter = this.enter(), update = this, exit = this.exit();\n  if (typeof onenter === \"function\") {\n    enter = onenter(enter);\n    if (enter) enter = enter.selection();\n  } else {\n    enter = enter.append(onenter + \"\");\n  }\n  if (onupdate != null) {\n    update = onupdate(update);\n    if (update) update = update.selection();\n  }\n  if (onexit == null) exit.remove(); else onexit(exit);\n  return enter && update ? enter.merge(update).order() : update;\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(context) {\n  var selection = context.selection ? context.selection() : context;\n\n  for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Selection(merges, this._parents);\n}\n","export default function() {\n\n  for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n    for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n      if (node = group[i]) {\n        if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);\n        next = node;\n      }\n    }\n  }\n\n  return this;\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(compare) {\n  if (!compare) compare = ascending;\n\n  function compareNode(a, b) {\n    return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n  }\n\n  for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        sortgroup[i] = node;\n      }\n    }\n    sortgroup.sort(compareNode);\n  }\n\n  return new Selection(sortgroups, this._parents).order();\n}\n\nfunction ascending(a, b) {\n  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","export default function() {\n  var callback = arguments[0];\n  arguments[0] = this;\n  callback.apply(null, arguments);\n  return this;\n}\n","export default function() {\n  return Array.from(this);\n}\n","export default function() {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n      var node = group[i];\n      if (node) return node;\n    }\n  }\n\n  return null;\n}\n","export default function() {\n  let size = 0;\n  for (const node of this) ++size; // eslint-disable-line no-unused-vars\n  return size;\n}\n","export default function() {\n  return !this.node();\n}\n","export default function(callback) {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n      if (node = group[i]) callback.call(node, node.__data__, i, group);\n    }\n  }\n\n  return this;\n}\n","import namespace from \"../namespace.js\";\n\nfunction attrRemove(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant(name, value) {\n  return function() {\n    this.setAttribute(name, value);\n  };\n}\n\nfunction attrConstantNS(fullname, value) {\n  return function() {\n    this.setAttributeNS(fullname.space, fullname.local, value);\n  };\n}\n\nfunction attrFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttribute(name);\n    else this.setAttribute(name, v);\n  };\n}\n\nfunction attrFunctionNS(fullname, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n    else this.setAttributeNS(fullname.space, fullname.local, v);\n  };\n}\n\nexport default function(name, value) {\n  var fullname = namespace(name);\n\n  if (arguments.length < 2) {\n    var node = this.node();\n    return fullname.local\n        ? node.getAttributeNS(fullname.space, fullname.local)\n        : node.getAttribute(fullname);\n  }\n\n  return this.each((value == null\n      ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS : attrFunction)\n      : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n}\n","export default function(node) {\n  return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n      || (node.document && node) // node is a Window\n      || node.defaultView; // node is a Document\n}\n","import defaultView from \"../window.js\";\n\nfunction styleRemove(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant(name, value, priority) {\n  return function() {\n    this.style.setProperty(name, value, priority);\n  };\n}\n\nfunction styleFunction(name, value, priority) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.style.removeProperty(name);\n    else this.style.setProperty(name, v, priority);\n  };\n}\n\nexport default function(name, value, priority) {\n  return arguments.length > 1\n      ? this.each((value == null\n            ? styleRemove : typeof value === \"function\"\n            ? styleFunction\n            : styleConstant)(name, value, priority == null ? \"\" : priority))\n      : styleValue(this.node(), name);\n}\n\nexport function styleValue(node, name) {\n  return node.style.getPropertyValue(name)\n      || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);\n}\n","function propertyRemove(name) {\n  return function() {\n    delete this[name];\n  };\n}\n\nfunction propertyConstant(name, value) {\n  return function() {\n    this[name] = value;\n  };\n}\n\nfunction propertyFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) delete this[name];\n    else this[name] = v;\n  };\n}\n\nexport default function(name, value) {\n  return arguments.length > 1\n      ? this.each((value == null\n          ? propertyRemove : typeof value === \"function\"\n          ? propertyFunction\n          : propertyConstant)(name, value))\n      : this.node()[name];\n}\n","function classArray(string) {\n  return string.trim().split(/^|\\s+/);\n}\n\nfunction classList(node) {\n  return node.classList || new ClassList(node);\n}\n\nfunction ClassList(node) {\n  this._node = node;\n  this._names = classArray(node.getAttribute(\"class\") || \"\");\n}\n\nClassList.prototype = {\n  add: function(name) {\n    var i = this._names.indexOf(name);\n    if (i < 0) {\n      this._names.push(name);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  remove: function(name) {\n    var i = this._names.indexOf(name);\n    if (i >= 0) {\n      this._names.splice(i, 1);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  contains: function(name) {\n    return this._names.indexOf(name) >= 0;\n  }\n};\n\nfunction classedAdd(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.add(names[i]);\n}\n\nfunction classedRemove(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.remove(names[i]);\n}\n\nfunction classedTrue(names) {\n  return function() {\n    classedAdd(this, names);\n  };\n}\n\nfunction classedFalse(names) {\n  return function() {\n    classedRemove(this, names);\n  };\n}\n\nfunction classedFunction(names, value) {\n  return function() {\n    (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n  };\n}\n\nexport default function(name, value) {\n  var names = classArray(name + \"\");\n\n  if (arguments.length < 2) {\n    var list = classList(this.node()), i = -1, n = names.length;\n    while (++i < n) if (!list.contains(names[i])) return false;\n    return true;\n  }\n\n  return this.each((typeof value === \"function\"\n      ? classedFunction : value\n      ? classedTrue\n      : classedFalse)(names, value));\n}\n","function textRemove() {\n  this.textContent = \"\";\n}\n\nfunction textConstant(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.textContent = v == null ? \"\" : v;\n  };\n}\n\nexport default function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? textRemove : (typeof value === \"function\"\n          ? textFunction\n          : textConstant)(value))\n      : this.node().textContent;\n}\n","function htmlRemove() {\n  this.innerHTML = \"\";\n}\n\nfunction htmlConstant(value) {\n  return function() {\n    this.innerHTML = value;\n  };\n}\n\nfunction htmlFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.innerHTML = v == null ? \"\" : v;\n  };\n}\n\nexport default function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? htmlRemove : (typeof value === \"function\"\n          ? htmlFunction\n          : htmlConstant)(value))\n      : this.node().innerHTML;\n}\n","function raise() {\n  if (this.nextSibling) this.parentNode.appendChild(this);\n}\n\nexport default function() {\n  return this.each(raise);\n}\n","function lower() {\n  if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n}\n\nexport default function() {\n  return this.each(lower);\n}\n","import creator from \"../creator.js\";\n\nexport default function(name) {\n  var create = typeof name === \"function\" ? name : creator(name);\n  return this.select(function() {\n    return this.appendChild(create.apply(this, arguments));\n  });\n}\n","import creator from \"../creator.js\";\nimport selector from \"../selector.js\";\n\nfunction constantNull() {\n  return null;\n}\n\nexport default function(name, before) {\n  var create = typeof name === \"function\" ? name : creator(name),\n      select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n  return this.select(function() {\n    return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n  });\n}\n","function remove() {\n  var parent = this.parentNode;\n  if (parent) parent.removeChild(this);\n}\n\nexport default function() {\n  return this.each(remove);\n}\n","function selection_cloneShallow() {\n  var clone = this.cloneNode(false), parent = this.parentNode;\n  return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nfunction selection_cloneDeep() {\n  var clone = this.cloneNode(true), parent = this.parentNode;\n  return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nexport default function(deep) {\n  return this.select(deep ? selection_cloneDeep : selection_cloneShallow);\n}\n","export default function(value) {\n  return arguments.length\n      ? this.property(\"__data__\", value)\n      : this.node().__data__;\n}\n","function contextListener(listener) {\n  return function(event) {\n    listener.call(this, event, this.__data__);\n  };\n}\n\nfunction parseTypenames(typenames) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    return {type: t, name: name};\n  });\n}\n\nfunction onRemove(typename) {\n  return function() {\n    var on = this.__on;\n    if (!on) return;\n    for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n      if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.options);\n      } else {\n        on[++i] = o;\n      }\n    }\n    if (++i) on.length = i;\n    else delete this.__on;\n  };\n}\n\nfunction onAdd(typename, value, options) {\n  return function() {\n    var on = this.__on, o, listener = contextListener(value);\n    if (on) for (var j = 0, m = on.length; j < m; ++j) {\n      if ((o = on[j]).type === typename.type && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.options);\n        this.addEventListener(o.type, o.listener = listener, o.options = options);\n        o.value = value;\n        return;\n      }\n    }\n    this.addEventListener(typename.type, listener, options);\n    o = {type: typename.type, name: typename.name, value: value, listener: listener, options: options};\n    if (!on) this.__on = [o];\n    else on.push(o);\n  };\n}\n\nexport default function(typename, value, options) {\n  var typenames = parseTypenames(typename + \"\"), i, n = typenames.length, t;\n\n  if (arguments.length < 2) {\n    var on = this.node().__on;\n    if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n      for (i = 0, o = on[j]; i < n; ++i) {\n        if ((t = typenames[i]).type === o.type && t.name === o.name) {\n          return o.value;\n        }\n      }\n    }\n    return;\n  }\n\n  on = value ? onAdd : onRemove;\n  for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));\n  return this;\n}\n","import defaultView from \"../window.js\";\n\nfunction dispatchEvent(node, type, params) {\n  var window = defaultView(node),\n      event = window.CustomEvent;\n\n  if (typeof event === \"function\") {\n    event = new event(type, params);\n  } else {\n    event = window.document.createEvent(\"Event\");\n    if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n    else event.initEvent(type, false, false);\n  }\n\n  node.dispatchEvent(event);\n}\n\nfunction dispatchConstant(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params);\n  };\n}\n\nfunction dispatchFunction(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params.apply(this, arguments));\n  };\n}\n\nexport default function(type, params) {\n  return this.each((typeof params === \"function\"\n      ? dispatchFunction\n      : dispatchConstant)(type, params));\n}\n","export default function*() {\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n      if (node = group[i]) yield node;\n    }\n  }\n}\n","import selection_select from \"./select.js\";\nimport selection_selectAll from \"./selectAll.js\";\nimport selection_selectChild from \"./selectChild.js\";\nimport selection_selectChildren from \"./selectChildren.js\";\nimport selection_filter from \"./filter.js\";\nimport selection_data from \"./data.js\";\nimport selection_enter from \"./enter.js\";\nimport selection_exit from \"./exit.js\";\nimport selection_join from \"./join.js\";\nimport selection_merge from \"./merge.js\";\nimport selection_order from \"./order.js\";\nimport selection_sort from \"./sort.js\";\nimport selection_call from \"./call.js\";\nimport selection_nodes from \"./nodes.js\";\nimport selection_node from \"./node.js\";\nimport selection_size from \"./size.js\";\nimport selection_empty from \"./empty.js\";\nimport selection_each from \"./each.js\";\nimport selection_attr from \"./attr.js\";\nimport selection_style from \"./style.js\";\nimport selection_property from \"./property.js\";\nimport selection_classed from \"./classed.js\";\nimport selection_text from \"./text.js\";\nimport selection_html from \"./html.js\";\nimport selection_raise from \"./raise.js\";\nimport selection_lower from \"./lower.js\";\nimport selection_append from \"./append.js\";\nimport selection_insert from \"./insert.js\";\nimport selection_remove from \"./remove.js\";\nimport selection_clone from \"./clone.js\";\nimport selection_datum from \"./datum.js\";\nimport selection_on from \"./on.js\";\nimport selection_dispatch from \"./dispatch.js\";\nimport selection_iterator from \"./iterator.js\";\n\nexport var root = [null];\n\nexport function Selection(groups, parents) {\n  this._groups = groups;\n  this._parents = parents;\n}\n\nfunction selection() {\n  return new Selection([[document.documentElement]], root);\n}\n\nfunction selection_selection() {\n  return this;\n}\n\nSelection.prototype = selection.prototype = {\n  constructor: Selection,\n  select: selection_select,\n  selectAll: selection_selectAll,\n  selectChild: selection_selectChild,\n  selectChildren: selection_selectChildren,\n  filter: selection_filter,\n  data: selection_data,\n  enter: selection_enter,\n  exit: selection_exit,\n  join: selection_join,\n  merge: selection_merge,\n  selection: selection_selection,\n  order: selection_order,\n  sort: selection_sort,\n  call: selection_call,\n  nodes: selection_nodes,\n  node: selection_node,\n  size: selection_size,\n  empty: selection_empty,\n  each: selection_each,\n  attr: selection_attr,\n  style: selection_style,\n  property: selection_property,\n  classed: selection_classed,\n  text: selection_text,\n  html: selection_html,\n  raise: selection_raise,\n  lower: selection_lower,\n  append: selection_append,\n  insert: selection_insert,\n  remove: selection_remove,\n  clone: selection_clone,\n  datum: selection_datum,\n  on: selection_on,\n  dispatch: selection_dispatch,\n  [Symbol.iterator]: selection_iterator\n};\n\nexport default selection;\n","export default function(constructor, factory, prototype) {\n  constructor.prototype = factory.prototype = prototype;\n  prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n  var prototype = Object.create(parent.prototype);\n  for (var key in definition) prototype[key] = definition[key];\n  return prototype;\n}\n","import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n    reN = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n    reP = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n    reHex = /^#([0-9a-f]{3,8})$/,\n    reRgbInteger = new RegExp(`^rgb\\\\(${reI},${reI},${reI}\\\\)$`),\n    reRgbPercent = new RegExp(`^rgb\\\\(${reP},${reP},${reP}\\\\)$`),\n    reRgbaInteger = new RegExp(`^rgba\\\\(${reI},${reI},${reI},${reN}\\\\)$`),\n    reRgbaPercent = new RegExp(`^rgba\\\\(${reP},${reP},${reP},${reN}\\\\)$`),\n    reHslPercent = new RegExp(`^hsl\\\\(${reN},${reP},${reP}\\\\)$`),\n    reHslaPercent = new RegExp(`^hsla\\\\(${reN},${reP},${reP},${reN}\\\\)$`);\n\nvar named = {\n  aliceblue: 0xf0f8ff,\n  antiquewhite: 0xfaebd7,\n  aqua: 0x00ffff,\n  aquamarine: 0x7fffd4,\n  azure: 0xf0ffff,\n  beige: 0xf5f5dc,\n  bisque: 0xffe4c4,\n  black: 0x000000,\n  blanchedalmond: 0xffebcd,\n  blue: 0x0000ff,\n  blueviolet: 0x8a2be2,\n  brown: 0xa52a2a,\n  burlywood: 0xdeb887,\n  cadetblue: 0x5f9ea0,\n  chartreuse: 0x7fff00,\n  chocolate: 0xd2691e,\n  coral: 0xff7f50,\n  cornflowerblue: 0x6495ed,\n  cornsilk: 0xfff8dc,\n  crimson: 0xdc143c,\n  cyan: 0x00ffff,\n  darkblue: 0x00008b,\n  darkcyan: 0x008b8b,\n  darkgoldenrod: 0xb8860b,\n  darkgray: 0xa9a9a9,\n  darkgreen: 0x006400,\n  darkgrey: 0xa9a9a9,\n  darkkhaki: 0xbdb76b,\n  darkmagenta: 0x8b008b,\n  darkolivegreen: 0x556b2f,\n  darkorange: 0xff8c00,\n  darkorchid: 0x9932cc,\n  darkred: 0x8b0000,\n  darksalmon: 0xe9967a,\n  darkseagreen: 0x8fbc8f,\n  darkslateblue: 0x483d8b,\n  darkslategray: 0x2f4f4f,\n  darkslategrey: 0x2f4f4f,\n  darkturquoise: 0x00ced1,\n  darkviolet: 0x9400d3,\n  deeppink: 0xff1493,\n  deepskyblue: 0x00bfff,\n  dimgray: 0x696969,\n  dimgrey: 0x696969,\n  dodgerblue: 0x1e90ff,\n  firebrick: 0xb22222,\n  floralwhite: 0xfffaf0,\n  forestgreen: 0x228b22,\n  fuchsia: 0xff00ff,\n  gainsboro: 0xdcdcdc,\n  ghostwhite: 0xf8f8ff,\n  gold: 0xffd700,\n  goldenrod: 0xdaa520,\n  gray: 0x808080,\n  green: 0x008000,\n  greenyellow: 0xadff2f,\n  grey: 0x808080,\n  honeydew: 0xf0fff0,\n  hotpink: 0xff69b4,\n  indianred: 0xcd5c5c,\n  indigo: 0x4b0082,\n  ivory: 0xfffff0,\n  khaki: 0xf0e68c,\n  lavender: 0xe6e6fa,\n  lavenderblush: 0xfff0f5,\n  lawngreen: 0x7cfc00,\n  lemonchiffon: 0xfffacd,\n  lightblue: 0xadd8e6,\n  lightcoral: 0xf08080,\n  lightcyan: 0xe0ffff,\n  lightgoldenrodyellow: 0xfafad2,\n  lightgray: 0xd3d3d3,\n  lightgreen: 0x90ee90,\n  lightgrey: 0xd3d3d3,\n  lightpink: 0xffb6c1,\n  lightsalmon: 0xffa07a,\n  lightseagreen: 0x20b2aa,\n  lightskyblue: 0x87cefa,\n  lightslategray: 0x778899,\n  lightslategrey: 0x778899,\n  lightsteelblue: 0xb0c4de,\n  lightyellow: 0xffffe0,\n  lime: 0x00ff00,\n  limegreen: 0x32cd32,\n  linen: 0xfaf0e6,\n  magenta: 0xff00ff,\n  maroon: 0x800000,\n  mediumaquamarine: 0x66cdaa,\n  mediumblue: 0x0000cd,\n  mediumorchid: 0xba55d3,\n  mediumpurple: 0x9370db,\n  mediumseagreen: 0x3cb371,\n  mediumslateblue: 0x7b68ee,\n  mediumspringgreen: 0x00fa9a,\n  mediumturquoise: 0x48d1cc,\n  mediumvioletred: 0xc71585,\n  midnightblue: 0x191970,\n  mintcream: 0xf5fffa,\n  mistyrose: 0xffe4e1,\n  moccasin: 0xffe4b5,\n  navajowhite: 0xffdead,\n  navy: 0x000080,\n  oldlace: 0xfdf5e6,\n  olive: 0x808000,\n  olivedrab: 0x6b8e23,\n  orange: 0xffa500,\n  orangered: 0xff4500,\n  orchid: 0xda70d6,\n  palegoldenrod: 0xeee8aa,\n  palegreen: 0x98fb98,\n  paleturquoise: 0xafeeee,\n  palevioletred: 0xdb7093,\n  papayawhip: 0xffefd5,\n  peachpuff: 0xffdab9,\n  peru: 0xcd853f,\n  pink: 0xffc0cb,\n  plum: 0xdda0dd,\n  powderblue: 0xb0e0e6,\n  purple: 0x800080,\n  rebeccapurple: 0x663399,\n  red: 0xff0000,\n  rosybrown: 0xbc8f8f,\n  royalblue: 0x4169e1,\n  saddlebrown: 0x8b4513,\n  salmon: 0xfa8072,\n  sandybrown: 0xf4a460,\n  seagreen: 0x2e8b57,\n  seashell: 0xfff5ee,\n  sienna: 0xa0522d,\n  silver: 0xc0c0c0,\n  skyblue: 0x87ceeb,\n  slateblue: 0x6a5acd,\n  slategray: 0x708090,\n  slategrey: 0x708090,\n  snow: 0xfffafa,\n  springgreen: 0x00ff7f,\n  steelblue: 0x4682b4,\n  tan: 0xd2b48c,\n  teal: 0x008080,\n  thistle: 0xd8bfd8,\n  tomato: 0xff6347,\n  turquoise: 0x40e0d0,\n  violet: 0xee82ee,\n  wheat: 0xf5deb3,\n  white: 0xffffff,\n  whitesmoke: 0xf5f5f5,\n  yellow: 0xffff00,\n  yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n  copy(channels) {\n    return Object.assign(new this.constructor, this, channels);\n  },\n  displayable() {\n    return this.rgb().displayable();\n  },\n  hex: color_formatHex, // Deprecated! Use color.formatHex.\n  formatHex: color_formatHex,\n  formatHex8: color_formatHex8,\n  formatHsl: color_formatHsl,\n  formatRgb: color_formatRgb,\n  toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n  return this.rgb().formatHex();\n}\n\nfunction color_formatHex8() {\n  return this.rgb().formatHex8();\n}\n\nfunction color_formatHsl() {\n  return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n  return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n  var m, l;\n  format = (format + \"\").trim().toLowerCase();\n  return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n      : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n      : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n      : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n      : null) // invalid hex\n      : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n      : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n      : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n      : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n      : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n      : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n      : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n      : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n      : null;\n}\n\nfunction rgbn(n) {\n  return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n  if (a <= 0) r = g = b = NaN;\n  return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Rgb;\n  o = o.rgb();\n  return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n  return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n  this.r = +r;\n  this.g = +g;\n  this.b = +b;\n  this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n  brighter(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  darker(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  rgb() {\n    return this;\n  },\n  clamp() {\n    return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n  },\n  displayable() {\n    return (-0.5 <= this.r && this.r < 255.5)\n        && (-0.5 <= this.g && this.g < 255.5)\n        && (-0.5 <= this.b && this.b < 255.5)\n        && (0 <= this.opacity && this.opacity <= 1);\n  },\n  hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n  formatHex: rgb_formatHex,\n  formatHex8: rgb_formatHex8,\n  formatRgb: rgb_formatRgb,\n  toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n  return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n  return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n  const a = clampa(this.opacity);\n  return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n  return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n  return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n  value = clampi(value);\n  return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n  if (a <= 0) h = s = l = NaN;\n  else if (l <= 0 || l >= 1) h = s = NaN;\n  else if (s <= 0) h = NaN;\n  return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n  if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Hsl;\n  if (o instanceof Hsl) return o;\n  o = o.rgb();\n  var r = o.r / 255,\n      g = o.g / 255,\n      b = o.b / 255,\n      min = Math.min(r, g, b),\n      max = Math.max(r, g, b),\n      h = NaN,\n      s = max - min,\n      l = (max + min) / 2;\n  if (s) {\n    if (r === max) h = (g - b) / s + (g < b) * 6;\n    else if (g === max) h = (b - r) / s + 2;\n    else h = (r - g) / s + 4;\n    s /= l < 0.5 ? max + min : 2 - max - min;\n    h *= 60;\n  } else {\n    s = l > 0 && l < 1 ? 0 : h;\n  }\n  return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n  return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n  this.h = +h;\n  this.s = +s;\n  this.l = +l;\n  this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n  brighter(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  darker(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  rgb() {\n    var h = this.h % 360 + (this.h < 0) * 360,\n        s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n        l = this.l,\n        m2 = l + (l < 0.5 ? l : 1 - l) * s,\n        m1 = 2 * l - m2;\n    return new Rgb(\n      hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n      hsl2rgb(h, m1, m2),\n      hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n      this.opacity\n    );\n  },\n  clamp() {\n    return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n  },\n  displayable() {\n    return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n        && (0 <= this.l && this.l <= 1)\n        && (0 <= this.opacity && this.opacity <= 1);\n  },\n  formatHsl() {\n    const a = clampa(this.opacity);\n    return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n  }\n}));\n\nfunction clamph(value) {\n  value = (value || 0) % 360;\n  return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n  return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n  return (h < 60 ? m1 + (m2 - m1) * h / 60\n      : h < 180 ? m2\n      : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n      : m1) * 255;\n}\n","export default x => () => x;\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n  return function(t) {\n    return a + t * d;\n  };\n}\n\nfunction exponential(a, b, y) {\n  return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n    return Math.pow(a + t * b, y);\n  };\n}\n\nexport function hue(a, b) {\n  var d = b - a;\n  return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n  return (y = +y) === 1 ? nogamma : function(a, b) {\n    return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n  };\n}\n\nexport default function nogamma(a, b) {\n  var d = b - a;\n  return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n  var color = gamma(y);\n\n  function rgb(start, end) {\n    var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n        g = color(start.g, end.g),\n        b = color(start.b, end.b),\n        opacity = nogamma(start.opacity, end.opacity);\n    return function(t) {\n      start.r = r(t);\n      start.g = g(t);\n      start.b = b(t);\n      start.opacity = opacity(t);\n      return start + \"\";\n    };\n  }\n\n  rgb.gamma = rgbGamma;\n\n  return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n  return function(colors) {\n    var n = colors.length,\n        r = new Array(n),\n        g = new Array(n),\n        b = new Array(n),\n        i, color;\n    for (i = 0; i < n; ++i) {\n      color = colorRgb(colors[i]);\n      r[i] = color.r || 0;\n      g[i] = color.g || 0;\n      b[i] = color.b || 0;\n    }\n    r = spline(r);\n    g = spline(g);\n    b = spline(b);\n    color.opacity = 1;\n    return function(t) {\n      color.r = r(t);\n      color.g = g(t);\n      color.b = b(t);\n      return color + \"\";\n    };\n  };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","export default function(a, b) {\n  return a = +a, b = +b, function(t) {\n    return a * (1 - t) + b * t;\n  };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n    reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n  return function() {\n    return b;\n  };\n}\n\nfunction one(b) {\n  return function(t) {\n    return b(t) + \"\";\n  };\n}\n\nexport default function(a, b) {\n  var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n      am, // current match in a\n      bm, // current match in b\n      bs, // string preceding current number in b, if any\n      i = -1, // index in s\n      s = [], // string constants and placeholders\n      q = []; // number interpolators\n\n  // Coerce inputs to strings.\n  a = a + \"\", b = b + \"\";\n\n  // Interpolate pairs of numbers in a & b.\n  while ((am = reA.exec(a))\n      && (bm = reB.exec(b))) {\n    if ((bs = bm.index) > bi) { // a string precedes the next number in b\n      bs = b.slice(bi, bs);\n      if (s[i]) s[i] += bs; // coalesce with previous string\n      else s[++i] = bs;\n    }\n    if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n      if (s[i]) s[i] += bm; // coalesce with previous string\n      else s[++i] = bm;\n    } else { // interpolate non-matching numbers\n      s[++i] = null;\n      q.push({i: i, x: number(am, bm)});\n    }\n    bi = reB.lastIndex;\n  }\n\n  // Add remains of b.\n  if (bi < b.length) {\n    bs = b.slice(bi);\n    if (s[i]) s[i] += bs; // coalesce with previous string\n    else s[++i] = bs;\n  }\n\n  // Special optimization for only a single match.\n  // Otherwise, interpolate each of the numbers and rejoin the string.\n  return s.length < 2 ? (q[0]\n      ? one(q[0].x)\n      : zero(b))\n      : (b = q.length, function(t) {\n          for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n          return s.join(\"\");\n        });\n}\n","var degrees = 180 / Math.PI;\n\nexport var identity = {\n  translateX: 0,\n  translateY: 0,\n  rotate: 0,\n  skewX: 0,\n  scaleX: 1,\n  scaleY: 1\n};\n\nexport default function(a, b, c, d, e, f) {\n  var scaleX, scaleY, skewX;\n  if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n  if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n  if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n  if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n  return {\n    translateX: e,\n    translateY: f,\n    rotate: Math.atan2(b, a) * degrees,\n    skewX: Math.atan(skewX) * degrees,\n    scaleX: scaleX,\n    scaleY: scaleY\n  };\n}\n","import decompose, {identity} from \"./decompose.js\";\n\nvar svgNode;\n\n/* eslint-disable no-undef */\nexport function parseCss(value) {\n  const m = new (typeof DOMMatrix === \"function\" ? DOMMatrix : WebKitCSSMatrix)(value + \"\");\n  return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);\n}\n\nexport function parseSvg(value) {\n  if (value == null) return identity;\n  if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n  svgNode.setAttribute(\"transform\", value);\n  if (!(value = svgNode.transform.baseVal.consolidate())) return identity;\n  value = value.matrix;\n  return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n}\n","import number from \"../number.js\";\nimport {parseCss, parseSvg} from \"./parse.js\";\n\nfunction interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n  function pop(s) {\n    return s.length ? s.pop() + \" \" : \"\";\n  }\n\n  function translate(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n      q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n    } else if (xb || yb) {\n      s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n    }\n  }\n\n  function rotate(a, b, s, q) {\n    if (a !== b) {\n      if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n      q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: number(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"rotate(\" + b + degParen);\n    }\n  }\n\n  function skewX(a, b, s, q) {\n    if (a !== b) {\n      q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: number(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"skewX(\" + b + degParen);\n    }\n  }\n\n  function scale(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n      q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n    } else if (xb !== 1 || yb !== 1) {\n      s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n    }\n  }\n\n  return function(a, b) {\n    var s = [], // string constants and placeholders\n        q = []; // number interpolators\n    a = parse(a), b = parse(b);\n    translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n    rotate(a.rotate, b.rotate, s, q);\n    skewX(a.skewX, b.skewX, s, q);\n    scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n    a = b = null; // gc\n    return function(t) {\n      var i = -1, n = q.length, o;\n      while (++i < n) s[(o = q[i]).i] = o.x(t);\n      return s.join(\"\");\n    };\n  };\n}\n\nexport var interpolateTransformCss = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\nexport var interpolateTransformSvg = interpolateTransform(parseSvg, \", \", \")\", \")\");\n","var frame = 0, // is an animation frame pending?\n    timeout = 0, // is a timeout pending?\n    interval = 0, // are any timers active?\n    pokeDelay = 1000, // how frequently we check for clock skew\n    taskHead,\n    taskTail,\n    clockLast = 0,\n    clockNow = 0,\n    clockSkew = 0,\n    clock = typeof performance === \"object\" && performance.now ? performance : Date,\n    setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n  return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n  clockNow = 0;\n}\n\nexport function Timer() {\n  this._call =\n  this._time =\n  this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n  constructor: Timer,\n  restart: function(callback, delay, time) {\n    if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n    time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n    if (!this._next && taskTail !== this) {\n      if (taskTail) taskTail._next = this;\n      else taskHead = this;\n      taskTail = this;\n    }\n    this._call = callback;\n    this._time = time;\n    sleep();\n  },\n  stop: function() {\n    if (this._call) {\n      this._call = null;\n      this._time = Infinity;\n      sleep();\n    }\n  }\n};\n\nexport function timer(callback, delay, time) {\n  var t = new Timer;\n  t.restart(callback, delay, time);\n  return t;\n}\n\nexport function timerFlush() {\n  now(); // Get the current time, if not already set.\n  ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n  var t = taskHead, e;\n  while (t) {\n    if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);\n    t = t._next;\n  }\n  --frame;\n}\n\nfunction wake() {\n  clockNow = (clockLast = clock.now()) + clockSkew;\n  frame = timeout = 0;\n  try {\n    timerFlush();\n  } finally {\n    frame = 0;\n    nap();\n    clockNow = 0;\n  }\n}\n\nfunction poke() {\n  var now = clock.now(), delay = now - clockLast;\n  if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n  var t0, t1 = taskHead, t2, time = Infinity;\n  while (t1) {\n    if (t1._call) {\n      if (time > t1._time) time = t1._time;\n      t0 = t1, t1 = t1._next;\n    } else {\n      t2 = t1._next, t1._next = null;\n      t1 = t0 ? t0._next = t2 : taskHead = t2;\n    }\n  }\n  taskTail = t0;\n  sleep(time);\n}\n\nfunction sleep(time) {\n  if (frame) return; // Soonest alarm already set, or will be.\n  if (timeout) timeout = clearTimeout(timeout);\n  var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n  if (delay > 24) {\n    if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n    if (interval) interval = clearInterval(interval);\n  } else {\n    if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n    frame = 1, setFrame(wake);\n  }\n}\n","import {Timer} from \"./timer.js\";\n\nexport default function(callback, delay, time) {\n  var t = new Timer;\n  delay = delay == null ? 0 : +delay;\n  t.restart(elapsed => {\n    t.stop();\n    callback(elapsed + delay);\n  }, delay, time);\n  return t;\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {timer, timeout} from \"d3-timer\";\n\nvar emptyOn = dispatch(\"start\", \"end\", \"cancel\", \"interrupt\");\nvar emptyTween = [];\n\nexport var CREATED = 0;\nexport var SCHEDULED = 1;\nexport var STARTING = 2;\nexport var STARTED = 3;\nexport var RUNNING = 4;\nexport var ENDING = 5;\nexport var ENDED = 6;\n\nexport default function(node, name, id, index, group, timing) {\n  var schedules = node.__transition;\n  if (!schedules) node.__transition = {};\n  else if (id in schedules) return;\n  create(node, id, {\n    name: name,\n    index: index, // For context during callback.\n    group: group, // For context during callback.\n    on: emptyOn,\n    tween: emptyTween,\n    time: timing.time,\n    delay: timing.delay,\n    duration: timing.duration,\n    ease: timing.ease,\n    timer: null,\n    state: CREATED\n  });\n}\n\nexport function init(node, id) {\n  var schedule = get(node, id);\n  if (schedule.state > CREATED) throw new Error(\"too late; already scheduled\");\n  return schedule;\n}\n\nexport function set(node, id) {\n  var schedule = get(node, id);\n  if (schedule.state > STARTED) throw new Error(\"too late; already running\");\n  return schedule;\n}\n\nexport function get(node, id) {\n  var schedule = node.__transition;\n  if (!schedule || !(schedule = schedule[id])) throw new Error(\"transition not found\");\n  return schedule;\n}\n\nfunction create(node, id, self) {\n  var schedules = node.__transition,\n      tween;\n\n  // Initialize the self timer when the transition is created.\n  // Note the actual delay is not known until the first callback!\n  schedules[id] = self;\n  self.timer = timer(schedule, 0, self.time);\n\n  function schedule(elapsed) {\n    self.state = SCHEDULED;\n    self.timer.restart(start, self.delay, self.time);\n\n    // If the elapsed delay is less than our first sleep, start immediately.\n    if (self.delay <= elapsed) start(elapsed - self.delay);\n  }\n\n  function start(elapsed) {\n    var i, j, n, o;\n\n    // If the state is not SCHEDULED, then we previously errored on start.\n    if (self.state !== SCHEDULED) return stop();\n\n    for (i in schedules) {\n      o = schedules[i];\n      if (o.name !== self.name) continue;\n\n      // While this element already has a starting transition during this frame,\n      // defer starting an interrupting transition until that transition has a\n      // chance to tick (and possibly end); see d3/d3-transition#54!\n      if (o.state === STARTED) return timeout(start);\n\n      // Interrupt the active transition, if any.\n      if (o.state === RUNNING) {\n        o.state = ENDED;\n        o.timer.stop();\n        o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n        delete schedules[i];\n      }\n\n      // Cancel any pre-empted transitions.\n      else if (+i < id) {\n        o.state = ENDED;\n        o.timer.stop();\n        o.on.call(\"cancel\", node, node.__data__, o.index, o.group);\n        delete schedules[i];\n      }\n    }\n\n    // Defer the first tick to end of the current frame; see d3/d3#1576.\n    // Note the transition may be canceled after start and before the first tick!\n    // Note this must be scheduled before the start event; see d3/d3-transition#16!\n    // Assuming this is successful, subsequent callbacks go straight to tick.\n    timeout(function() {\n      if (self.state === STARTED) {\n        self.state = RUNNING;\n        self.timer.restart(tick, self.delay, self.time);\n        tick(elapsed);\n      }\n    });\n\n    // Dispatch the start event.\n    // Note this must be done before the tween are initialized.\n    self.state = STARTING;\n    self.on.call(\"start\", node, node.__data__, self.index, self.group);\n    if (self.state !== STARTING) return; // interrupted\n    self.state = STARTED;\n\n    // Initialize the tween, deleting null tween.\n    tween = new Array(n = self.tween.length);\n    for (i = 0, j = -1; i < n; ++i) {\n      if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n        tween[++j] = o;\n      }\n    }\n    tween.length = j + 1;\n  }\n\n  function tick(elapsed) {\n    var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),\n        i = -1,\n        n = tween.length;\n\n    while (++i < n) {\n      tween[i].call(node, t);\n    }\n\n    // Dispatch the end event.\n    if (self.state === ENDING) {\n      self.on.call(\"end\", node, node.__data__, self.index, self.group);\n      stop();\n    }\n  }\n\n  function stop() {\n    self.state = ENDED;\n    self.timer.stop();\n    delete schedules[id];\n    for (var i in schedules) return; // eslint-disable-line no-unused-vars\n    delete node.__transition;\n  }\n}\n","import {STARTING, ENDING, ENDED} from \"./transition/schedule.js\";\n\nexport default function(node, name) {\n  var schedules = node.__transition,\n      schedule,\n      active,\n      empty = true,\n      i;\n\n  if (!schedules) return;\n\n  name = name == null ? null : name + \"\";\n\n  for (i in schedules) {\n    if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n    active = schedule.state > STARTING && schedule.state < ENDING;\n    schedule.state = ENDED;\n    schedule.timer.stop();\n    schedule.on.call(active ? \"interrupt\" : \"cancel\", node, node.__data__, schedule.index, schedule.group);\n    delete schedules[i];\n  }\n\n  if (empty) delete node.__transition;\n}\n","import interrupt from \"../interrupt.js\";\n\nexport default function(name) {\n  return this.each(function() {\n    interrupt(this, name);\n  });\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction tweenRemove(id, name) {\n  var tween0, tween1;\n  return function() {\n    var schedule = set(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = tween0 = tween;\n      for (var i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1 = tween1.slice();\n          tween1.splice(i, 1);\n          break;\n        }\n      }\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nfunction tweenFunction(id, name, value) {\n  var tween0, tween1;\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    var schedule = set(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = (tween0 = tween).slice();\n      for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1[i] = t;\n          break;\n        }\n      }\n      if (i === n) tween1.push(t);\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nexport default function(name, value) {\n  var id = this._id;\n\n  name += \"\";\n\n  if (arguments.length < 2) {\n    var tween = get(this.node(), id).tween;\n    for (var i = 0, n = tween.length, t; i < n; ++i) {\n      if ((t = tween[i]).name === name) {\n        return t.value;\n      }\n    }\n    return null;\n  }\n\n  return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n}\n\nexport function tweenValue(transition, name, value) {\n  var id = transition._id;\n\n  transition.each(function() {\n    var schedule = set(this, id);\n    (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n  });\n\n  return function(node) {\n    return get(node, id).value[name];\n  };\n}\n","import {color} from \"d3-color\";\nimport {interpolateNumber, interpolateRgb, interpolateString} from \"d3-interpolate\";\n\nexport default function(a, b) {\n  var c;\n  return (typeof b === \"number\" ? interpolateNumber\n      : b instanceof color ? interpolateRgb\n      : (c = color(b)) ? (b = c, interpolateRgb)\n      : interpolateString)(a, b);\n}\n","import {interpolateTransformSvg as interpolateTransform} from \"d3-interpolate\";\nimport {namespace} from \"d3-selection\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction attrRemove(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant(name, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = this.getAttribute(name);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction attrConstantNS(fullname, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = this.getAttributeNS(fullname.space, fullname.local);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction attrFunction(name, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0, value1 = value(this), string1;\n    if (value1 == null) return void this.removeAttribute(name);\n    string0 = this.getAttribute(name);\n    string1 = value1 + \"\";\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nfunction attrFunctionNS(fullname, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0, value1 = value(this), string1;\n    if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n    string0 = this.getAttributeNS(fullname.space, fullname.local);\n    string1 = value1 + \"\";\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nexport default function(name, value) {\n  var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform : interpolate;\n  return this.attrTween(name, typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n      : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname)\n      : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));\n}\n","import {namespace} from \"d3-selection\";\n\nfunction attrInterpolate(name, i) {\n  return function(t) {\n    this.setAttribute(name, i.call(this, t));\n  };\n}\n\nfunction attrInterpolateNS(fullname, i) {\n  return function(t) {\n    this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));\n  };\n}\n\nfunction attrTweenNS(fullname, value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nfunction attrTween(name, value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(name, value) {\n  var key = \"attr.\" + name;\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  var fullname = namespace(name);\n  return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n}\n","import {get, init} from \"./schedule.js\";\n\nfunction delayFunction(id, value) {\n  return function() {\n    init(this, id).delay = +value.apply(this, arguments);\n  };\n}\n\nfunction delayConstant(id, value) {\n  return value = +value, function() {\n    init(this, id).delay = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? delayFunction\n          : delayConstant)(id, value))\n      : get(this.node(), id).delay;\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction durationFunction(id, value) {\n  return function() {\n    set(this, id).duration = +value.apply(this, arguments);\n  };\n}\n\nfunction durationConstant(id, value) {\n  return value = +value, function() {\n    set(this, id).duration = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? durationFunction\n          : durationConstant)(id, value))\n      : get(this.node(), id).duration;\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction easeConstant(id, value) {\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    set(this, id).ease = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each(easeConstant(id, value))\n      : get(this.node(), id).ease;\n}\n","import {set} from \"./schedule.js\";\n\nfunction easeVarying(id, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (typeof v !== \"function\") throw new Error;\n    set(this, id).ease = v;\n  };\n}\n\nexport default function(value) {\n  if (typeof value !== \"function\") throw new Error;\n  return this.each(easeVarying(this._id, value));\n}\n","import {matcher} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\n\nexport default function(match) {\n  if (typeof match !== \"function\") match = matcher(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, this._name, this._id);\n}\n","import {Transition} from \"./index.js\";\n\nexport default function(transition) {\n  if (transition._id !== this._id) throw new Error;\n\n  for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Transition(merges, this._parents, this._name, this._id);\n}\n","import {get, set, init} from \"./schedule.js\";\n\nfunction start(name) {\n  return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n    var i = t.indexOf(\".\");\n    if (i >= 0) t = t.slice(0, i);\n    return !t || t === \"start\";\n  });\n}\n\nfunction onFunction(id, name, listener) {\n  var on0, on1, sit = start(name) ? init : set;\n  return function() {\n    var schedule = sit(this, id),\n        on = schedule.on;\n\n    // If this node shared a dispatch with the previous node,\n    // just assign the updated shared dispatch and we’re done!\n    // Otherwise, copy-on-write.\n    if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n    schedule.on = on1;\n  };\n}\n\nexport default function(name, listener) {\n  var id = this._id;\n\n  return arguments.length < 2\n      ? get(this.node(), id).on.on(name)\n      : this.each(onFunction(id, name, listener));\n}\n","function removeFunction(id) {\n  return function() {\n    var parent = this.parentNode;\n    for (var i in this.__transition) if (+i !== id) return;\n    if (parent) parent.removeChild(this);\n  };\n}\n\nexport default function() {\n  return this.on(\"end.remove\", removeFunction(this._id));\n}\n","import {selector} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select !== \"function\") select = selector(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n        schedule(subgroup[i], name, id, i, subgroup, get(node, id));\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, name, id);\n}\n","import {selectorAll} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select !== \"function\") select = selectorAll(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {\n          if (child = children[k]) {\n            schedule(child, name, id, k, children, inherit);\n          }\n        }\n        subgroups.push(children);\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, parents, name, id);\n}\n","import {selection} from \"d3-selection\";\n\nvar Selection = selection.prototype.constructor;\n\nexport default function() {\n  return new Selection(this._groups, this._parents);\n}\n","import {interpolateTransformCss as interpolateTransform} from \"d3-interpolate\";\nimport {style} from \"d3-selection\";\nimport {set} from \"./schedule.js\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction styleNull(name, interpolate) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0 = style(this, name),\n        string1 = (this.style.removeProperty(name), style(this, name));\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, string10 = string1);\n  };\n}\n\nfunction styleRemove(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant(name, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = style(this, name);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction styleFunction(name, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0 = style(this, name),\n        value1 = value(this),\n        string1 = value1 + \"\";\n    if (value1 == null) string1 = value1 = (this.style.removeProperty(name), style(this, name));\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nfunction styleMaybeRemove(id, name) {\n  var on0, on1, listener0, key = \"style.\" + name, event = \"end.\" + key, remove;\n  return function() {\n    var schedule = set(this, id),\n        on = schedule.on,\n        listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;\n\n    // If this node shared a dispatch with the previous node,\n    // just assign the updated shared dispatch and we’re done!\n    // Otherwise, copy-on-write.\n    if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);\n\n    schedule.on = on1;\n  };\n}\n\nexport default function(name, value, priority) {\n  var i = (name += \"\") === \"transform\" ? interpolateTransform : interpolate;\n  return value == null ? this\n      .styleTween(name, styleNull(name, i))\n      .on(\"end.style.\" + name, styleRemove(name))\n    : typeof value === \"function\" ? this\n      .styleTween(name, styleFunction(name, i, tweenValue(this, \"style.\" + name, value)))\n      .each(styleMaybeRemove(this._id, name))\n    : this\n      .styleTween(name, styleConstant(name, i, value), priority)\n      .on(\"end.style.\" + name, null);\n}\n","function styleInterpolate(name, i, priority) {\n  return function(t) {\n    this.style.setProperty(name, i.call(this, t), priority);\n  };\n}\n\nfunction styleTween(name, value, priority) {\n  var t, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);\n    return t;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(name, value, priority) {\n  var key = \"style.\" + (name += \"\");\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n}\n","import {tweenValue} from \"./tween.js\";\n\nfunction textConstant(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction(value) {\n  return function() {\n    var value1 = value(this);\n    this.textContent = value1 == null ? \"\" : value1;\n  };\n}\n\nexport default function(value) {\n  return this.tween(\"text\", typeof value === \"function\"\n      ? textFunction(tweenValue(this, \"text\", value))\n      : textConstant(value == null ? \"\" : value + \"\"));\n}\n","function textInterpolate(i) {\n  return function(t) {\n    this.textContent = i.call(this, t);\n  };\n}\n\nfunction textTween(value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && textInterpolate(i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(value) {\n  var key = \"text\";\n  if (arguments.length < 1) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  return this.tween(key, textTween(value));\n}\n","import {Transition, newId} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function() {\n  var name = this._name,\n      id0 = this._id,\n      id1 = newId();\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        var inherit = get(node, id0);\n        schedule(node, name, id1, i, group, {\n          time: inherit.time + inherit.delay + inherit.duration,\n          delay: 0,\n          duration: inherit.duration,\n          ease: inherit.ease\n        });\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id1);\n}\n","import {set} from \"./schedule.js\";\n\nexport default function() {\n  var on0, on1, that = this, id = that._id, size = that.size();\n  return new Promise(function(resolve, reject) {\n    var cancel = {value: reject},\n        end = {value: function() { if (--size === 0) resolve(); }};\n\n    that.each(function() {\n      var schedule = set(this, id),\n          on = schedule.on;\n\n      // If this node shared a dispatch with the previous node,\n      // just assign the updated shared dispatch and we’re done!\n      // Otherwise, copy-on-write.\n      if (on !== on0) {\n        on1 = (on0 = on).copy();\n        on1._.cancel.push(cancel);\n        on1._.interrupt.push(cancel);\n        on1._.end.push(end);\n      }\n\n      schedule.on = on1;\n    });\n\n    // The selection was empty, resolve end immediately\n    if (size === 0) resolve();\n  });\n}\n","import {selection} from \"d3-selection\";\nimport transition_attr from \"./attr.js\";\nimport transition_attrTween from \"./attrTween.js\";\nimport transition_delay from \"./delay.js\";\nimport transition_duration from \"./duration.js\";\nimport transition_ease from \"./ease.js\";\nimport transition_easeVarying from \"./easeVarying.js\";\nimport transition_filter from \"./filter.js\";\nimport transition_merge from \"./merge.js\";\nimport transition_on from \"./on.js\";\nimport transition_remove from \"./remove.js\";\nimport transition_select from \"./select.js\";\nimport transition_selectAll from \"./selectAll.js\";\nimport transition_selection from \"./selection.js\";\nimport transition_style from \"./style.js\";\nimport transition_styleTween from \"./styleTween.js\";\nimport transition_text from \"./text.js\";\nimport transition_textTween from \"./textTween.js\";\nimport transition_transition from \"./transition.js\";\nimport transition_tween from \"./tween.js\";\nimport transition_end from \"./end.js\";\n\nvar id = 0;\n\nexport function Transition(groups, parents, name, id) {\n  this._groups = groups;\n  this._parents = parents;\n  this._name = name;\n  this._id = id;\n}\n\nexport default function transition(name) {\n  return selection().transition(name);\n}\n\nexport function newId() {\n  return ++id;\n}\n\nvar selection_prototype = selection.prototype;\n\nTransition.prototype = transition.prototype = {\n  constructor: Transition,\n  select: transition_select,\n  selectAll: transition_selectAll,\n  selectChild: selection_prototype.selectChild,\n  selectChildren: selection_prototype.selectChildren,\n  filter: transition_filter,\n  merge: transition_merge,\n  selection: transition_selection,\n  transition: transition_transition,\n  call: selection_prototype.call,\n  nodes: selection_prototype.nodes,\n  node: selection_prototype.node,\n  size: selection_prototype.size,\n  empty: selection_prototype.empty,\n  each: selection_prototype.each,\n  on: transition_on,\n  attr: transition_attr,\n  attrTween: transition_attrTween,\n  style: transition_style,\n  styleTween: transition_styleTween,\n  text: transition_text,\n  textTween: transition_textTween,\n  remove: transition_remove,\n  tween: transition_tween,\n  delay: transition_delay,\n  duration: transition_duration,\n  ease: transition_ease,\n  easeVarying: transition_easeVarying,\n  end: transition_end,\n  [Symbol.iterator]: selection_prototype[Symbol.iterator]\n};\n","export function cubicIn(t) {\n  return t * t * t;\n}\n\nexport function cubicOut(t) {\n  return --t * t * t + 1;\n}\n\nexport function cubicInOut(t) {\n  return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n","import {Transition, newId} from \"../transition/index.js\";\nimport schedule from \"../transition/schedule.js\";\nimport {easeCubicInOut} from \"d3-ease\";\nimport {now} from \"d3-timer\";\n\nvar defaultTiming = {\n  time: null, // Set on use.\n  delay: 0,\n  duration: 250,\n  ease: easeCubicInOut\n};\n\nfunction inherit(node, id) {\n  var timing;\n  while (!(timing = node.__transition) || !(timing = timing[id])) {\n    if (!(node = node.parentNode)) {\n      throw new Error(`transition ${id} not found`);\n    }\n  }\n  return timing;\n}\n\nexport default function(name) {\n  var id,\n      timing;\n\n  if (name instanceof Transition) {\n    id = name._id, name = name._name;\n  } else {\n    id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n  }\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        schedule(node, name, id, i, group, timing || inherit(node, id));\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id);\n}\n","import {selection} from \"d3-selection\";\nimport selection_interrupt from \"./interrupt.js\";\nimport selection_transition from \"./transition.js\";\n\nselection.prototype.interrupt = selection_interrupt;\nselection.prototype.transition = selection_transition;\n","export function Transform(k, x, y) {\n  this.k = k;\n  this.x = x;\n  this.y = y;\n}\n\nTransform.prototype = {\n  constructor: Transform,\n  scale: function(k) {\n    return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n  },\n  translate: function(x, y) {\n    return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n  },\n  apply: function(point) {\n    return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n  },\n  applyX: function(x) {\n    return x * this.k + this.x;\n  },\n  applyY: function(y) {\n    return y * this.k + this.y;\n  },\n  invert: function(location) {\n    return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n  },\n  invertX: function(x) {\n    return (x - this.x) / this.k;\n  },\n  invertY: function(y) {\n    return (y - this.y) / this.k;\n  },\n  rescaleX: function(x) {\n    return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n  },\n  rescaleY: function(y) {\n    return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n  },\n  toString: function() {\n    return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n  }\n};\n\nexport var identity = new Transform(1, 0, 0);\n\ntransform.prototype = Transform.prototype;\n\nexport default function transform(node) {\n  while (!node.__zoom) if (!(node = node.parentNode)) return identity;\n  return node.__zoom;\n}\n","\n/*\n  HTDMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    k = discount factor (0, Infinity)\n\n  Behavioral variables:\n    A = amount\n    D = delay\n    V = subjective value\n\n  Equations:\n    V = A / (1 + kD)\n    k = (A - V) / (VD)\n*/\nexport default class HTDMath {\n  static k = {\n    DEFAULT: 0.05,\n    MIN: 0,\n    MAX: 100,\n    STEP: 0.001,\n    JUMP: 0.01,\n  };\n\n  static adk2v(a, d, k) {\n    return a / (1 + k * d);\n  }\n\n  static adv2k(a, d, v) {\n    return (a - v) / (v * d);\n  }\n}\n","\n// Internal dependencies\nimport HTDMath from './htd-math';\n\nexport default HTDMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\n// Needed for d3 in WebWorker!\nimport 'regenerator-runtime/runtime';\n\nimport * as BayesDistributions from 'bayes.js/distributions';\nimport * as BayesMcmc from 'bayes.js/mcmc';\nimport * as d3 from 'd3';\nimport HTDMath from '@decidables/discountable-math';\n\nself.onmessage = (event) => {\n  const params = {\n    k: {type: 'real', lower: HTDMath.k.MIN, upper: HTDMath.k.MAX},\n    luce: {type: 'real', lower: 0, upper: 100},\n  };\n\n  const logPost = (state, data) => {\n    let lp = 0;\n\n    // Priors\n    const kMean = 2;\n    const kShape = 3;\n    lp += BayesDistributions.gamma(\n      state.k,\n      kShape,\n      kShape / kMean,\n    );\n    // lp += BayesDistributions.unif(state.k, 0, 100);\n\n    const luceMean = 2;\n    const luceShape = 3;\n    lp += BayesDistributions.gamma(\n      state.luce,\n      luceShape,\n      luceShape / luceMean,\n    );\n    // lp += BayesDistributions.unif(state.luce, 0, 100);\n\n    // Likelihood\n    data.forEach((choice) => {\n      // Values\n      const vs = HTDMath.adk2v(choice.as, choice.ds, state.k);\n      const vl = HTDMath.adk2v(choice.al, choice.dl, state.k);\n\n      // Choice of sooner or later is sampled from a Bernoulli distribution\n      // Luce choice rule is used to compute probability of waiting! (0 = sooner, 1 = later)\n      const binval = 1 / (1 + Math.exp(state.luce * (vs - vl)));\n\n      // Actual response\n      const response = (choice.response === 'first') ? 0 : 1;\n\n      lp += BayesDistributions.bern(response, binval);\n    });\n\n    return lp;\n  };\n\n  // Initializing the sampler\n  const sampler = new BayesMcmc.AmwgSampler(params, logPost, event.data);\n  // Burning some samples to the MCMC gods and sampling 5000 draws\n  sampler.burn(1000);\n  const samples = sampler.sample(5000);\n\n  // Extract summary stats\n  const results = {\n    k: d3.median(samples.k),\n    luce: d3.median(samples.luce),\n  };\n\n  self.postMessage({results: results, samples: samples});\n};\n"],"names":["root","factory","module","exports","ld","this","lgamma","x","j","cof","ser","xx","y","tmp","log","lfactorial","n","NaN","lchoose","k","lbeta","a","b","Math","exp","abs","pow","sqrt","pi","PI","beta","shape1","shape2","Infinity","cauchy","location","scale","norm","mean","sd","bivarnorm","corr","z","normalizing_factor","bivar_log_dens","laplace","dexp","gamma","shape","rate","invgamma","lnorm","meanlog","sdlog","pareto","t","df","weibull","tmp1","tmp2","logis","e","f","dirichlet","alpha","sum_alpha","sum_lgamma_alpha","sum_alpha_sub_1_log_x","length","i","unif","min","max","bern","prob","cat","probs","binom","size","nbinom","hyper","m","pois","lambda","mcmc","runif","random","runif_discrete","floor","rnorm","u","v","q","deep_clone","src","mixin","dest","source","copyFunc","name","s","empty","Object","prototype","toString","call","nodeType","cloneNode","Date","getTime","RegExp","r","l","Array","push","constructor","clone_param_draw","isArray","x_copy","slice","is_number","object","Number","create_array","dim","init","arr","array_dim","concat","array_equal","a1","a2","nested_array_apply","fun","result","shuffle_array","array","temp","nested_array_random_apply","len","array_is","array_i","get_option","option_name","options","defaul_value","hasOwnProperty","undefined","get_multidim_option","value","param_init_fixed","type","lower","upper","round","complete_params","params_to_complete","param_init","params","param_name","param","Stepper","state","log_post","step","start_adaptation","stop_adaptation","info","OnedimMetropolisStepper","generate_proposal","param_names","keys","prop_log_scale","batch_size","max_adaptation","initial_adaptation","target_accept_rate","is_adapting","acceptance_count","batch_count","iterations_since_adaption","create","param_state","param_proposal","curr_log_dens","prop_log_dens","accept_prob","log_sd_adjustment","normal_proposal","RealMetropolisStepper","discrete_normal_proposal","IntMetropolisStepper","MultidimComponentMetropolisStepper","SubStepper","create_substeppers","substate","substeppers","suboptions","subparam","substepper","MultiRealComponentMetropolisStepper","MultiIntComponentMetropolisStepper","BinaryStepper","zero_log_dens","one_log_dens","max_log_dens","zero_prob","BinaryComponentStepper","subparams","AmwgStepper","SelectStepper","param_object_wrap","param_options","Sampler","data","param_init_fun","thinning_interval","params_to_monitor","thin","monitor","steppers","create_stepper_ensamble","sample","n_iterations","monitored_params","curr_sample","burn","AmwgSampler","ascending","numbers","values","valueof","compareDefined","compare","ascendingDefined","TypeError","quickselect","left","right","newLeft","newRight","swap","quantile","p","Float64Array","from","isNaN","i0","value0","subarray","value1","median","noop","dispatch","arguments","_","test","Error","Dispatch","parseTypenames","typenames","types","trim","split","map","indexOf","on","typename","callback","T","get","set","copy","that","args","apply","c","xhtml","svg","xlink","xml","xmlns","prefix","namespaces","space","local","creatorInherit","document","ownerDocument","uri","namespaceURI","documentElement","createElement","createElementNS","creatorFixed","fullname","namespace","none","selector","querySelector","select","groups","_groups","subgroups","group","subgroup","node","subnode","__data__","Selection","_parents","querySelectorAll","arrayAll","selectorAll","parents","matches","childMatcher","find","childFind","match","children","childFirst","firstElementChild","filter","childrenFilter","selectAll","matcher","update","_enter","sparse","EnterNode","parent","datum","_next","_parent","appendChild","child","insertBefore","next","bindIndex","enter","exit","groupLength","dataLength","bindKey","key","nodeByKeyValue","Map","keyValues","keyValue","has","delete","bind","constant","arraylike","enterGroup","updateGroup","exitGroup","i1","previous","_exit","onenter","onupdate","onexit","selection","append","remove","merge","order","context","groups0","groups1","m0","m1","merges","group0","group1","compareDocumentPosition","parentNode","compareNode","sortgroups","sortgroup","sort","attrRemove","removeAttribute","attrRemoveNS","removeAttributeNS","attrConstant","setAttribute","attrConstantNS","setAttributeNS","attrFunction","attrFunctionNS","getAttributeNS","getAttribute","each","defaultView","styleRemove","style","removeProperty","styleConstant","priority","setProperty","styleFunction","styleValue","getPropertyValue","getComputedStyle","propertyRemove","propertyConstant","propertyFunction","classArray","string","classList","ClassList","_node","_names","add","join","splice","contains","classedAdd","names","list","classedRemove","classedTrue","classedFalse","classedFunction","textRemove","textContent","textConstant","textFunction","htmlRemove","innerHTML","htmlConstant","htmlFunction","raise","nextSibling","previousSibling","firstChild","creator","constantNull","before","removeChild","selection_cloneShallow","clone","selection_cloneDeep","deep","property","contextListener","listener","event","onRemove","__on","o","removeEventListener","onAdd","addEventListener","dispatchEvent","window","CustomEvent","createEvent","initEvent","bubbles","cancelable","detail","dispatchConstant","dispatchFunction","selection_selection","selection_select","selection_selectAll","selectChild","selection_selectChild","selectChildren","selection_selectChildren","selection_filter","selection_data","selection_enter","selection_exit","selection_join","selection_merge","selection_order","selection_sort","selection_call","nodes","selection_nodes","selection_node","selection_size","selection_empty","selection_each","attr","selection_attr","selection_style","selection_property","classed","selection_classed","text","selection_text","html","selection_html","selection_raise","selection_lower","selection_append","insert","selection_insert","selection_remove","selection_clone","selection_datum","selection_on","selection_dispatch","Symbol","iterator","selection_iterator","extend","definition","Color","darker","brighter","reI","reN","reP","reHex","reRgbInteger","reRgbPercent","reRgbaInteger","reRgbaPercent","reHslPercent","reHslaPercent","named","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","define","color","channels","assign","displayable","rgb","hex","color_formatHex","formatHex","formatHex8","color_formatHex8","formatHsl","color_formatHsl","formatRgb","color_formatRgb","hslConvert","format","toLowerCase","exec","parseInt","rgbn","Rgb","rgba","hsla","g","rgbConvert","opacity","clamp","clampi","clampa","rgb_formatHex","rgb_formatHex8","rgb_formatRgb","h","Hsl","hsl","m2","hsl2rgb","clamph","clampt","linear","d","exponential","nogamma","rgbGamma","start","end","colorRgb","reA","reB","zero","one","bi","lastIndex","am","bm","bs","index","number","degrees","identity","translateX","translateY","rotate","skewX","scaleX","scaleY","atan2","atan","svgNode","parseCss","DOMMatrix","WebKitCSSMatrix","isIdentity","decompose","parseSvg","transform","baseVal","consolidate","matrix","interpolateTransform","parse","pxComma","pxParen","degParen","pop","translate","xa","ya","xb","yb","interpolateTransformCss","interpolateTransformSvg","frame","timeout","interval","pokeDelay","taskHead","taskTail","clockLast","clockNow","clockSkew","clock","performance","now","setFrame","requestAnimationFrame","setTimeout","clearNow","Timer","_call","_time","timer","restart","delay","time","sleep","stop","timerFlush","wake","nap","poke","t0","t1","t2","clearTimeout","clearInterval","setInterval","elapsed","emptyOn","emptyTween","CREATED","SCHEDULED","STARTING","STARTED","RUNNING","ENDING","ENDED","id","timing","schedules","__transition","tween","duration","ease","schedule","self","tick","active","interrupt","tweenRemove","tween0","tween1","tweenFunction","_id","tweenValue","transition","interpolateNumber","interpolateRgb","interpolateString","interpolate","string00","string1","interpolate0","string0","string10","attrTween","attrInterpolate","attrInterpolateNS","attrTweenNS","_value","delayFunction","delayConstant","durationFunction","durationConstant","easeConstant","easeVarying","Transition","_name","every","onFunction","on0","on1","sit","removeFunction","inherit","styleNull","styleMaybeRemove","listener0","styleTween","styleInterpolate","textInterpolate","textTween","id0","id1","newId","Promise","resolve","reject","cancel","selection_prototype","transition_select","transition_selectAll","transition_filter","transition_merge","transition_selection","transition_transition","transition_on","transition_attr","transition_attrTween","transition_style","transition_styleTween","transition_text","transition_textTween","transition_remove","transition_tween","transition_delay","transition_duration","transition_ease","transition_easeVarying","transition_end","cubicInOut","defaultTiming","easeCubicInOut","selection_interrupt","selection_transition","Transform","point","applyX","applyY","invert","invertX","invertY","rescaleX","domain","range","rescaleY","HTDMath","DEFAULT","MIN","MAX","STEP","JUMP","adk2v","adv2k","onmessage","luce","logPost","lp","kMean","kShape","BayesDistributions","luceMean","luceShape","forEach","choice","vs","as","ds","vl","al","dl","binval","response","sampler","BayesMcmc","samples","results","d3","postMessage"],"mappings":"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","x_google_ignoreList":[0,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]}');
22857
+ var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  var distributions$1 = {exports: {}};

  var distributions = distributions$1.exports;
  (function (module) {

    // A number of log probability density functions (PDF). Naming and parameterization
    // should match R's, except for that all functions reside in an ld object (
    // as in "log density"), so to get a normal log density you would write
    // ld.norm(...).
    // Most of the code below is directly taken from the great Jstat project
    // (https://github.com/jstat/) which includes PDF for many common probability
    // distributions. What I have done is only to convert these to log PDFs.

    /*
    Original work Copyright (c) 2013 jStat
    Modified work Copyright (c) 2015 Rasmus Bååth 
    	Permission is hereby granted, free of charge, to any person obtaining a copy
    of this software and associated documentation files (the "Software"), to deal
    in the Software without restriction, including without limitation the rights
    to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    copies of the Software, and to permit persons to whom the Software is
    furnished to do so, subject to the following conditions:
    	The above copyright notice and this permission notice shall be included in
    all copies or substantial portions of the Software.
    	THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    THE SOFTWARE.
    	*/

    // This boiler plate code here is taken from:
    // https://github.com/umdjs/umd/blob/master/templates/returnExports.js
    // It should make shure that module can be imported both in the browser,
    // Node, and by using the Asynchronous Module Definition standard.
    // If this module is loaded in the browser it will created the global
    // object ld .
    (function (root, factory) {
      if (module.exports) {
        // Node. Does not work with strict CommonJS, but
        // only CommonJS-like environments that support module.exports,
        // like Node.
        module.exports = factory();
      } else {
        // Browser globals (root is window)
        root.ld = factory();
      }
    })(distributions, function () {
      // Object to hold the functions to be exported.
      var ld = {};

      ////////// Helper functions //////////
      //////////////////////////////////////

      var lgamma = function (x) {
        var j = 0;
        var cof = [76.18009172947146, -86.50532032941678, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -5395239384953e-18];
        var ser = 1.000000000190015;
        var xx, y, tmp;
        tmp = (y = xx = x) + 5.5;
        tmp -= (xx + 0.5) * log(tmp);
        for (; j < 6; j++) ser += cof[j] / ++y;
        return log(2.5066282746310005 * ser / xx) - tmp;
      };
      ld.lgamma = lgamma;
      var lfactorial = function (n) {
        return n < 0 ? NaN : lgamma(n + 1);
      };
      ld.lfactorial = lfactorial;
      var lchoose = function (n, k) {
        return lfactorial(n) - lfactorial(k) - lfactorial(n - k);
      };
      ld.lchoose = lchoose;
      var lbeta = function (a, b) {
        return lgamma(a) + lgamma(b) - lgamma(a + b);
      };
      ld.lbeta = lbeta;
      var log = Math.log;
      var exp = Math.exp;
      var abs = Math.abs;
      var pow = Math.pow;
      var sqrt = Math.sqrt;
      var pi = Math.PI;

      ////////// Continous distributions //////////
      /////////////////////////////////////////////

      ld.beta = function (x, shape1, shape2) {
        if (x > 1 || x < 0) {
          return -Infinity;
        }
        if (shape1 === 1 && shape2 === 1) {
          return 0;
        } else {
          return (shape1 - 1) * log(x) + (shape2 - 1) * log(1 - x) - lbeta(shape1, shape2);
        }
      };
      ld.cauchy = function (x, location, scale) {
        return log(scale) - log(pow(x - location, 2) + pow(scale, 2)) - log(pi);
      };
      ld.norm = function (x, mean, sd) {
        return -0.5 * log(2 * pi) - log(sd) - pow(x - mean, 2) / (2 * sd * sd);
      };

      // A bivariate Normal distribution parameterized by arrays of two means and SDs, and 
      // the correlation.
      ld.bivarnorm = function (x, mean, sd, corr) {
        var z = pow(x[0] - mean[0], 2) / pow(sd[0], 2) + pow(x[1] - mean[1], 2) / pow(sd[1], 2) - 2 * corr * (x[0] - mean[0]) * (x[1] - mean[1]) / (sd[0] * sd[1]);
        var normalizing_factor = -(log(2) + log(pi) + log(sd[0]) + log(sd[1]) + 0.5 * log(1 - pow(corr, 2)));
        var bivar_log_dens = normalizing_factor - z / (2 * (1 - pow(corr, 2)));
        return bivar_log_dens;
      };
      ld.laplace = function (x, location, scale) {
        return -abs(x - location) / scale - log(2 * scale);
      };
      ld.dexp = ld.laplace;
      ld.gamma = function (x, shape, rate) {
        var scale = 1 / rate;
        if (x < 0) {
          return -Infinity;
        }
        if (x === 0 && shape === 1) {
          return -log(scale);
        } else {
          return (shape - 1) * log(x) - x / scale - lgamma(shape) - shape * log(scale);
        }
      };
      ld.invgamma = function (x, shape, scale) {
        if (x <= 0) {
          return -Infinity;
        }
        return -(shape + 1) * log(x) - scale / x - lgamma(shape) + shape * log(scale);
      };
      ld.lnorm = function (x, meanlog, sdlog) {
        if (x <= 0) {
          return -Infinity;
        }
        return -log(x) - 0.5 * log(2 * pi) - log(sdlog) - pow(log(x) - meanlog, 2) / (2 * sdlog * sdlog);
      };
      ld.pareto = function (x, scale, shape) {
        if (x < scale) {
          return -Infinity;
        }
        return log(shape) + shape * log(scale) - (shape + 1) * log(x);
      };
      ld.t = function (x, location, scale, df) {
        df = df > 1e100 ? 1e100 : df;
        return lgamma((df + 1) / 2) - lgamma(df / 2) - log(sqrt(pi * df) * scale) + log(pow(1 + 1 / df * pow((x - location) / scale, 2), -(df + 1) / 2));
      };

      // This is a direct javascript translation of the R code used to evaluate
      // the log density of a weibull distribution: 
      // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dweibull.c
      ld.weibull = function (x, shape, scale) {
        if (x < 0) return -Infinity;
        if (x === 0 && shape < 1) return Infinity;
        var tmp1 = pow(x / scale, shape - 1);
        var tmp2 = tmp1 * (x / scale);
        return -tmp2 + log(shape * tmp1 / scale);
      };

      // This is a direct javascript translation of the R code used to evaluate
      // the log density of a logistic distribution: 
      // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dlogis.c
      ld.logis = function (x, location, scale) {
        x = abs((x - location) / scale);
        var e = exp(-x);
        var f = 1.0 + e;
        return -(x + log(scale * f * f));
      };
      ld.dirichlet = function (x, alpha) {
        var sum_alpha = 0;
        var sum_lgamma_alpha = 0;
        var sum_alpha_sub_1_log_x = 0;
        var n = alpha.length;
        for (var i = 0; i < n; i++) {
          sum_alpha += alpha[i];
          sum_lgamma_alpha += lgamma(alpha[i]);
          sum_alpha_sub_1_log_x += (alpha[i] - 1) * log(x[i]);
        }
        return lgamma(sum_alpha) - sum_lgamma_alpha + sum_alpha_sub_1_log_x;
      };
      ld.exp = function (x, rate) {
        return x < 0 ? -Infinity : log(rate) - rate * x;
      };
      ld.unif = function (x, min, max) {
        return x < min || x > max ? -Infinity : log(1 / (max - min));
      };

      ////////// Discrete distributions //////////
      ////////////////////////////////////////////

      ld.bern = function (x, prob) {
        return !(x === 0 || x === 1) ? -Infinity : log(x * prob + (1 - x) * (1 - prob));
      };
      ld.cat = function (x, probs) {
        if (x < 1 || x > probs.length) {
          return -Infinity;
        } else {
          return log(probs[x - 1]);
        }
      };
      ld.binom = function (x, size, prob) {
        if (x > size || x < 0) {
          return -Infinity;
        }
        if (prob === 0 || prob === 1) {
          return size * prob === x ? 0 : -Infinity;
        }
        return lchoose(size, x) + x * log(prob) + (size - x) * log(1 - prob);
      };
      ld.nbinom = function (x, size, prob) {
        if (x < 0) {
          return -Infinity;
        }
        return lchoose(x + size - 1, size - 1) + x * log(1 - prob) + size * log(prob);
      };
      ld.hyper = function (x, m, n, k) {
        if (x < 0 || x > k) {
          return -Infinity;
        } else {
          return lchoose(m, x) + lchoose(n, k - x) - lchoose(m + n, k);
        }
      };
      ld.pois = function (x, lambda) {
        return x < 0 ? -Infinity : log(lambda) * x - lambda - lfactorial(x);
      };
      return ld;
    });
  })(distributions$1);
  var distributionsExports = distributions$1.exports;

  var mcmc$1 = {exports: {}};

  var mcmc = mcmc$1.exports;
  (function (module) {

    // This boiler plate code here is taken from:
    // https://github.com/umdjs/umd/blob/master/templates/returnExports.js
    // It should make shure that module can be imported both in the browser,
    // Node, and by using the Asynchronous Module Definition standard.
    // If this module is loaded in the browser it will created the global
    // object mcmc .
    (function (root, factory) {
      if (module.exports) {
        // Node. Does not work with strict CommonJS, but
        // only CommonJS-like environments that support module.exports,
        // like Node.
        module.exports = factory();
      } else {
        // Browser globals (root is window)
        root.mcmc = factory();
      }
    })(mcmc, function () {
      /// The actual module code starts here ///
      //////////////////////////////////////////  

      ////////// Helper Functions //////////
      //////////////////////////////////////

      /** Returns a random real number between min and max */
      var runif = function (min, max) {
        return Math.random() * (max - min) + min;
      };

      /** Returns a random integer between min and max */
      var runif_discrete = function (min, max) {
        return Math.floor(Math.random() * (max - min + 1)) + min;
      };

      /** Returns a random real number from a normal distribbution defined
       *  by mean and sd. 
       *  Adapted from https://github.com/jstat/jstat/blob/master/src/special.js */
      var rnorm = function (mean, sd) {
        var u, v, x, y, q;
        do {
          u = Math.random();
          v = 1.7156 * (Math.random() - 0.5);
          x = u - 0.449871;
          y = Math.abs(v) + 0.386595;
          q = x * x + y * (0.19600 * y - 0.25472 * x);
        } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u));
        return v / u * sd + mean;
      };

      /** Returns a deep clone of src, sort of... It only copies a limited
       * number of types and, for example, function are not copied. 
       * From http://davidwalsh.name/javascript-clone
       */
      var deep_clone = function (src) {
        function mixin(dest, source, copyFunc) {
          var name,
            s,
            empty = {};
          for (name in source) {
            // the (!(name in empty) || empty[name] !== s) condition avoids copying properties in "source"
            // inherited from Object.prototype.	 For example, if dest has a custom toString() method,
            // don't overwrite it with the toString() method that source inherited from Object.prototype
            s = source[name];
            if (!(name in dest) || dest[name] !== s && (!(name in empty) || empty[name] !== s)) {
              dest[name] = copyFunc ? copyFunc(s) : s;
            }
          }
          return dest;
        }
        if (!src || typeof src != "object" || Object.prototype.toString.call(src) === "[object Function]") {
          // null, undefined, any non-object, or function
          return src; // anything
        }
        if (src.nodeType && "cloneNode" in src) {
          // DOM Node
          return src.cloneNode(true); // Node
        }
        if (src instanceof Date) {
          // Date
          return new Date(src.getTime()); // Date
        }
        if (src instanceof RegExp) {
          // RegExp
          return new RegExp(src); // RegExp
        }
        var r, i, l;
        if (src instanceof Array) {
          // array
          r = [];
          for (i = 0, l = src.length; i < l; ++i) {
            if (i in src) {
              r.push(deep_clone(src[i]));
            }
          }
        } else {
          // generic objects
          r = src.constructor ? new src.constructor() : {};
        }
        return mixin(r, src, deep_clone);
      };

      /** Specialized clone function that only clones scalars and nested arrays where
       * each array either consists of all arrays or all numbers. This function
       * is meant as a fast way of cloning parameter draws within the mcmc sampling
       * loop.
       */
      var clone_param_draw = function (x) {
        if (Array.isArray(x)) {
          if (Array.isArray(x[0])) {
            // x is an array of arrays so we need to clone it recursively
            var x_copy = [];
            for (var i = 0, length = x.length; i < length; i++) {
              x_copy.push(clone_param_draw(x[i]));
            }
            return x_copy;
          } else {
            // We'll assume x is a arrays of scalars
            return x.slice(0);
          }
        } else {
          // We'll assume x is a scalar
          return x;
        }
      };

      /** Returns true if object is a number.
       */
      var is_number = function (object) {
        return typeof object == "number" || typeof object == "object" && object.constructor === Number;
      };

      /**
       * Creates and initializes a (possibly multidimensional/nested) array.
       * @param dim - An array giving the dimension of the array. For example,
       *   [5] would yield a 5 element array, and [3,3] would yield a 3 by 3 matrix.
       * @param init - A value or a function used to fill in the each element in
       *   the array. If it is a function it should take no arguments, it will be 
       *   evaluated once for each element, and it's return value will be used to
       *   fill in each element.
       * @example 
       * // The following would return [[1,1],[1,1],[1,1]]
       * create_array([2,3], 1)
       */
      var create_array = function (dim, init) {
        var arr = new Array(dim[0]);
        var i;
        if (dim.length == 1) {
          // Fill it up with init
          if (typeof init === "function") {
            for (i = 0; i < dim[0]; i++) {
              arr[i] = init();
            }
          } else {
            for (i = 0; i < dim[0]; i++) {
              arr[i] = init;
            }
          }
        } else if (dim.length > 1) {
          for (i = 0; i < dim[0]; i++) {
            arr[i] = create_array(dim.slice(1), init);
          }
        } else {
          throw "create_array can't create a dimensionless array";
        }
        return arr;
      };

      /**
       * Return the dimensions of a possibly nested array as an array. For 
       * example, array_dim( [[1, 2], [1, 2]] ) should return [2, 2]
       * Assumes that all arrays inside another array are of the same length.
       * @example
       * // Should return [4, 2, 1]
       * array_dim(create_array([4, 2, 1], 0))
       */
      var array_dim = function (a) {
        if (Array.isArray(a[0])) {
          return [a.length].concat(array_dim(a[0]));
        } else {
          return [a.length];
        }
      };

      /**
       * Checks if two arrays are equal in the sense that they contain the same elements
       * as judged by the "==" operator. Returns true or false.
       * Adapted from http://stackoverflow.com/a/14853974/1001848
       */
      var array_equal = function (a1, a2) {
        if (a1.length != a2.length) return false;
        for (var i = 0; i < a1.length; i++) {
          // Check if we have nested arrays
          if (Array.isArray(a1[i]) && Array.isArray(a2[i])) {
            // recurse into the nested arrays
            if (!array_equal(a1[i], a2[i])) return false;
          } else if (a1[i] != a2[i]) {
            // Warning - two different object instances will never be equal: {x:20} != {x:20}
            return false;
          }
        }
        return true;
      };

      /**
       * Traverses a possibly nested array a and applies fun to all "leaf nodes", 
       * that is, values that are not arrays. Returns an array of the same size as
       * a.
       */
      var nested_array_apply = function (a, fun) {
        if (Array.isArray(a)) {
          var result = new Array(a.length);
          for (var i = 0; i < a.length; i++) {
            result[i] = nested_array_apply(a[i], fun);
          }
          return result;
        } else {
          return fun(a);
        }
      };

      /** Randomizing the array element order in-place. Using Durstenfeld
       * shuffle algorithm. Adapted from here: 
       * http://stackoverflow.com/a/12646864/1001848
       */
      function shuffle_array(array) {
        for (var i = array.length - 1; i > 0; i--) {
          var j = Math.floor(Math.random() * (i + 1));
          var temp = array[i];
          array[i] = array[j];
          array[j] = temp;
        }
        return array;
      }

      /**
       * Does the same thing as nested_array_apply, that is, traverses a possibly
       * nested array a and applies fun to all "leaf nodes" and returns an array 
       * of the same size as a. The difference is that nested_array_random_apply
       * branches randomly.
       */
      var nested_array_random_apply = function (a, fun) {
        if (Array.isArray(a)) {
          var len = a.length;
          var i;
          var array_is = [];
          for (i = 0; i < len; i++) {
            array_is[i] = i;
          }
          shuffle_array(array_is);
          var result = [];
          for (i = 0; i < len; i++) {
            var array_i = array_is[i];
            result[array_i] = nested_array_apply(a[array_i], fun);
          }
          return result;
        } else {
          return fun(a);
        }
      };

      /**
       * Allows a pretty way of setting default options where the defults can be
       * overridden by an options object.
       *  @param option_name - the name of the option as a string
       *  @param my_options - an option object that could have option_name 
       *    as a member.
       * @param defaul_value - defult value that is returned if option_name 
       *   is not defined in my_options.
       * @example
       * var my_options = {pi: 3.14159}
       * var pi = get_option("pi", my_options, 3.14)
       */
      // Pretty way of setting default options where the defaults can be overridden
      // by an options object. For example:
      // var pi = get_option("pi", my_options, 3.14)
      var get_option = function (option_name, options, defaul_value) {
        options = options || {};
        return options.hasOwnProperty(option_name) && options[option_name] !== undefined && options[option_name] !== null ? options[option_name] : defaul_value;
      };

      /** Version of get_option where the option should be a one or multi-dimensional
       * array and where the default can be overridden either by a scalar or by an array.
       * If it's a scalar the that scalar is used to initialize an array with 
       * dim dimensions.
       * 
       */
      var get_multidim_option = function (option_name, options, dim, defaul_value) {
        var value = get_option(option_name, options, defaul_value);
        if (!Array.isArray(value)) {
          value = create_array(dim, value);
        }
        if (!array_equal(array_dim(value), dim)) {
          throw "The option " + option_name + " is of dimension [" + array_dim(value) + "] but should be [" + dim + "].";
        }
        return value;
      };

      ////////// Functions for handling parameter objects //////////
      //////////////////////////////////////////////////////////////

      /**
       * Returns a fixed (same every time) number that could be used to initialize
       * a parameter of a certain type, possibly with lower and upper bounds.
       * The possile types are "real", "int", and "binary".
       */
      var param_init_fixed = function (type, lower, upper) {
        if (lower > upper) {
          throw "Can not initialize parameter where lower bound > upper bound";
        }
        if (type === "real") {
          if (lower === -Infinity && upper === Infinity) {
            return 0.5;
          } else if (lower === -Infinity) {
            return upper - 0.5;
          } else if (upper === Infinity) {
            return lower + 0.5;
          } else if (lower <= upper) {
            return (lower + upper) / 2;
          }
        } else if (type === "int") {
          if (lower === -Infinity && upper === Infinity) {
            return 1;
          } else if (lower === -Infinity) {
            return upper - 1;
          } else if (upper === Infinity) {
            return lower + 1;
          } else if (lower <= upper) {
            return Math.round((lower + upper) / 2);
          }
        } else if (type === "binary") {
          return 1;
        }
        throw "Could not initialize parameter of type " + type + "[" + lower + ", " + upper + "]";
      };

      /**
       * Completes params_to_complete, an object containing parameter descriptions, 
       * and initializes non-initialized parameters. This modified version of
       * params_to_complete is returned as a deep copy and not modified in place.
       * Initialization is done by supplying a param_init function with signature
       * function(type, lower, upper) that should return a single number 
       * (like param_init_fixed, for example).
       * @example
       * var params = { "mu": {"type": "real"} }
       * params = complete_params(params);
       * // params should now be:
       * //  {"mu": { "type": "real", "dim": [1], "upper": Infinity,
       * //           "lower": -Infinity, "init": 0.5 }}
       */
      var complete_params = function (params_to_complete, param_init) {
        var params = deep_clone(params_to_complete);
        for (var param_name in params) {
          if (!params.hasOwnProperty(param_name)) continue;
          var param = params[param_name];
          if (!param.hasOwnProperty("type")) {
            param.type = "real";
          }
          if (!param.hasOwnProperty("dim")) {
            param.dim = [1];
          }
          if (is_number(param.dim)) {
            param.dim = [param.dim];
          }
          if (param.type == "binary") {
            param.upper = 1;
            param.lower = 0;
          }
          if (!param.hasOwnProperty("upper")) {
            param.upper = Infinity;
          }
          if (!param.hasOwnProperty("lower")) {
            param.lower = -Infinity;
          }
          if (param.hasOwnProperty("init")) {
            // If this is just a number or a nested array we leave it alone, but if...
            if (array_equal(param.dim, [1]) && typeof param.init === "function") {
              // param.init is a function, use that to initialize the parameter.
              param.init = param.init();
            } else if (!array_equal(param.dim, [1]) && !Array.isArray(param.init)) {
              // We have a multidimensional parameter where the param.init exist but
              // is not an array. Then assume it is a number or a function and use
              // it to initialize the parameter.
              param.init = create_array(param.dim, param.init);
            }
          } else {
            // We use the default initialization function.
            if (array_equal(param.dim, [1])) {
              param.init = param_init(param.type, param.lower, param.upper);
            } else {
              param.init = create_array(param.dim, function () {
                return param_init(param.type, param.lower, param.upper);
              });
            }
          }
        }
        return params;
      };

      ////////// Stepper Functions ///////////
      ////////////////////////////////////////

      /**
       * @interface
       * A Stepper is an object responsible for pushing around one
       * or more parameter values in a state according to the distribution
       * defined by the log posterior. This defines the Stepper "interface",
       * where "interface" means that Stepper defines a class that is never
       * meant to be instantiated, but just to be subclassed by specialized
       * stepper functions.
       * @interface
       * @param params - An object with parameter definitions, for example:
       *   {"mu": { "type": "real", "dim": [1], "upper": Infinity, 
       *   "lower": -Infinity, "init": 0.5 }}
       *   The parameter definitions are expected to be "complete", that is,
       *   specifying all relevant attributes such as dim, lower and upper.
       * @param state - an object containing the state of all parameters in params
       *   (and possibly more). The parameter names are given as keys and the states
       *   as scalars or, possibly nested, arrays. For example:
       *   {mu: 10, sigma: 5, beta: [1, 2.5]}
       * @param log_post - A function *taking no parameters* that returns the
       *   log density that depends on the state. That is, the value of log_post
       *   should change if the the values in state are changed.
      
       */
      var Stepper = function (params, state, log_post) {
        this.params = params;
        this.state = state;
        this.log_post = log_post;
      };

      /**
       * Takes a step in the parameter space. Should return the new state,
       * but is mainly called for it's side effect of making a change in the
       * state object.
       */
      Stepper.prototype.step = function () {
        throw "Every Stepper need to implement step()";
      };

      /**
       * If implemented, makes the stepper adapt while stepping.
       */
      Stepper.prototype.start_adaptation = function () {
        // Optional, some steppers might not be adaptive. */ 
      };

      /**
       * If implemented, makes the stepper cease adapting while stepping.
       */
      Stepper.prototype.stop_adaptation = function () {
        // Optional, some steppers might not be adaptive. */ 
      };

      /**
       * Returns an object containg info regarding the stepper.
       */
      Stepper.prototype.info = function () {
        // Returns an object with info about the state of the stepper.
        return {};
      };

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements the metropolis step in
       * the Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
       * by Roberts and Rosenthal (2008).
       * @param params - An object with a single parameter definition.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
       * @param generate_proposal - a function returning a proposal (as a number)
       * with signature function(param_state, log_scale) where param_state is a
       * number and log_scale defines the scale of the proposal somehow.
      */
      var OnedimMetropolisStepper = function (params, state, log_post, options, generate_proposal) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length != 1) {
          throw "OnedimMetropolisStepper can only handle one parameter.";
        }
        this.param_name = param_names[0];
        var param = this.params[this.param_name];
        if (!array_equal(param.dim, [1])) {
          throw "OnedimMetropolisStepper can only handle one one-dimensional parameter.";
        }
        this.lower = param.lower;
        this.upper = param.upper;
        this.prop_log_scale = get_option("prop_log_scale", options, 0);
        this.batch_size = get_option("batch_size", options, 50);
        this.max_adaptation = get_option("max_adaptation", options, 0.33);
        this.initial_adaptation = get_option("initial_adaptation", options, 1.0);
        this.target_accept_rate = get_option("target_accept_rate", options, 0.44);
        this.is_adapting = get_option("is_adapting", options, true);
        this.generate_proposal = generate_proposal;
        this.acceptance_count = 0;
        this.batch_count = 0;
        this.iterations_since_adaption = 0;
      };
      OnedimMetropolisStepper.prototype = Object.create(Stepper.prototype);
      OnedimMetropolisStepper.prototype.constructor = OnedimMetropolisStepper;
      OnedimMetropolisStepper.prototype.step = function () {
        var param_state = this.state[this.param_name];
        var param_proposal = this.generate_proposal(param_state, this.prop_log_scale);
        if (param_proposal < this.lower || param_proposal > this.upper) ; else {
          // make a Metropolis step
          var curr_log_dens = this.log_post();
          this.state[this.param_name] = param_proposal;
          var prop_log_dens = this.log_post();
          var accept_prob = Math.exp(prop_log_dens - curr_log_dens);
          if (accept_prob > Math.random()) {
            // We do nothing as the state of param has already been changed to the proposal
            if (this.is_adapting) this.acceptance_count++;
          } else {
            // revert state back to the old state of param
            this.state[this.param_name] = param_state;
          }
        }
        if (this.is_adapting) {
          this.iterations_since_adaption++;
          if (this.iterations_since_adaption >= this.batch_size) {
            // then adapt
            this.batch_count++;
            var log_sd_adjustment = Math.min(this.max_adaptation, this.initial_adaptation / Math.sqrt(this.batch_count));
            if (this.acceptance_count / this.batch_size > this.target_accept_rate) {
              this.prop_log_scale += log_sd_adjustment;
            } else {
              this.prop_log_scale -= log_sd_adjustment;
            }
            this.acceptance_count = 0;
            this.iterations_since_adaption = 0;
          }
        }
        return this.state[this.param_name];
      };
      OnedimMetropolisStepper.prototype.start_adaptation = function () {
        this.is_adapting = true;
      };
      OnedimMetropolisStepper.prototype.stop_adaptation = function () {
        this.is_adapting = false;
      };
      OnedimMetropolisStepper.prototype.info = function () {
        return {
          prop_log_scale: this.prop_log_scale,
          is_adapting: this.is_adapting,
          acceptance_count: this.acceptance_count,
          iterations_since_adaption: this.iterations_since_adaption,
          batch_count: this.batch_count
        };
      };

      /**
       * Function returning a Normal proposal.
       */
      var normal_proposal = function (param_state, prop_log_scale) {
        return rnorm(param_state, Math.exp(prop_log_scale));
      };

      /**
       * @class
       * @augments {OnedimMetropolisStepper}
       * A "subclass" of OnedimMetropolisStepper making continous Normal proposals.
       */
      var RealMetropolisStepper = function (params, state, log_post, options) {
        OnedimMetropolisStepper.call(this, params, state, log_post, options, normal_proposal);
      };
      RealMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype);
      RealMetropolisStepper.prototype.constructor = RealMetropolisStepper;

      /**
       * Function returning a discretized Normal proposal.
       */
      var discrete_normal_proposal = function (param_state, prop_log_scale) {
        return Math.round(rnorm(param_state, Math.exp(prop_log_scale)));
      };

      /**
      * @class
      * @augments {OnedimMetropolisStepper}
      * A "subclass" of OnedimMetropolisStepper making discretized Normal proposals.
      */
      var IntMetropolisStepper = function (params, state, log_post, options) {
        OnedimMetropolisStepper.call(this, params, state, log_post, options, discrete_normal_proposal);
      };
      IntMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype);
      IntMetropolisStepper.prototype.constructor = IntMetropolisStepper;

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements the metropolis step in
       * the Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
       * by Roberts and Rosenthal (2008) for possibly multidimensional arrays. That
       * is, instead of just taking a step for a one-dimensional parameter like 
       * OnedimMetropolisStepper, this Stepper is responsible for taking steps 
       * for a multidimensional array. It's still pretty dumb and just takes
       * one-dimensional steps for each parameter component, though.
       * @param params - An object with a single parameter definition for a 
       *   multidimensional parameter.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
       * @param SubStepper - a constructor for the type of one dimensional Stepper to apply on
       *   all the components of the multidimensional parameter.
      */
      var MultidimComponentMetropolisStepper = function (params, state, log_post, options, SubStepper) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length != 1) {
          throw "MultidimComponentMetropolisStepper can't handle more than one parameter.";
        }
        this.param_name = param_names[0];
        var param = this.params[this.param_name];
        this.lower = param.lower;
        this.upper = param.upper;
        this.dim = param.dim;
        this.prop_log_scale = get_multidim_option("prop_log_scale", options, this.dim, 0);
        this.batch_size = get_multidim_option("batch_size", options, this.dim, 50);
        this.max_adaptation = get_multidim_option("max_adaptation", options, this.dim, 0.33);
        this.initial_adaptation = get_multidim_option("initial_adaptation", options, this.dim, 1.0);
        this.target_accept_rate = get_multidim_option("target_accept_rate", options, this.dim, 0.44);
        this.is_adapting = get_multidim_option("is_adapting", options, this.dim, true);

        // This hack below is a recursive function that creates an array of 
        // one dimensional steppers according to dim.
        var create_substeppers = function (dim, substate, log_post, prop_log_scale, batch_size, max_adaptation, initial_adaptation, target_accept_rate, is_adapting) {
          var substeppers = [];
          if (dim.length === 1) {
            for (var i = 0; i < dim[0]; i++) {
              var suboptions = {
                prop_log_scale: prop_log_scale[i],
                batch_size: batch_size[i],
                max_adaptation: max_adaptation[i],
                initial_adaptation: initial_adaptation[i],
                target_accept_rate: target_accept_rate[i],
                is_adapting: is_adapting[i]
              };
              var subparam = {};
              subparam[i] = deep_clone(param);
              subparam[i].dim = [1]; // As this should now be a one-dim parameter
              delete subparam[i].init; // As it sould not be needed
              substeppers[i] = new SubStepper(subparam, substate, log_post, suboptions);
            }
          } else {
            for (var i = 0; i < dim[0]; i++) {
              substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post, prop_log_scale[i], batch_size[i], max_adaptation[i], initial_adaptation[i], target_accept_rate[i], is_adapting[i]);
            }
          }
          return substeppers;
        };
        this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post, this.prop_log_scale, this.batch_size, this.max_adaptation, this.initial_adaptation, this.target_accept_rate, this.is_adapting);
      };
      MultidimComponentMetropolisStepper.prototype = Object.create(Stepper.prototype);
      MultidimComponentMetropolisStepper.prototype.constructor = MultidimComponentMetropolisStepper;
      MultidimComponentMetropolisStepper.prototype.step = function () {
        // Go through the substeppers in a random order and call step() on them.
        return nested_array_random_apply(this.substeppers, function (substepper) {
          return substepper.step();
        });
      };
      MultidimComponentMetropolisStepper.prototype.start_adaptation = function () {
        nested_array_apply(this.substeppers, function (substepper) {
          substepper.start_adaptation();
        });
      };
      MultidimComponentMetropolisStepper.prototype.stop_adaptation = function () {
        nested_array_apply(this.substeppers, function (substepper) {
          substepper.stop_adaptation();
        });
      };
      MultidimComponentMetropolisStepper.prototype.info = function () {
        return nested_array_apply(this.substeppers, function (substepper) {
          return substepper.info();
        });
      };

      /**
       * @class
       * @augments {MultidimComponentMetropolisStepper}
       * A "subclass" of MultidimComponentMetropolisStepper making continous Normal proposals.
       */
      var MultiRealComponentMetropolisStepper = function (params, state, log_post, options) {
        MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, RealMetropolisStepper);
      };
      MultiRealComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype);
      MultiRealComponentMetropolisStepper.prototype.constructor = MultiRealComponentMetropolisStepper;

      /**
       * @class
       * @augments {MultidimComponentMetropolisStepper}
       * A "subclass" of MultidimComponentMetropolisStepper making discretized Normal proposals.
       */
      var MultiIntComponentMetropolisStepper = function (params, state, log_post, options) {
        MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, IntMetropolisStepper);
      };
      MultiIntComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype);
      MultiIntComponentMetropolisStepper.prototype.constructor = MultiIntComponentMetropolisStepper;

      /**
       * @class
       * @implements {Stepper}
       * Constructor for an object that implements a step for a binary parameter.
       * This is done by evaluating the log posterior for both states of the
       * parameter and then selecting a state randomly with probability relative 
       * to the posterior of each state.
       * @param params - An object with a single parameter definition.
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
      */
      var BinaryStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length == 1) {
          this.param_name = param_names[0];
        } else {
          throw "BinaryStepper can't handle more than one parameter.";
        }
      };
      BinaryStepper.prototype = Object.create(Stepper.prototype);
      BinaryStepper.prototype.constructor = BinaryStepper;
      BinaryStepper.prototype.step = function () {
        this.state[this.param_name] = 0;
        var zero_log_dens = this.log_post();
        this.state[this.param_name] = 1;
        var one_log_dens = this.log_post();
        var max_log_dens = Math.max(zero_log_dens, one_log_dens);
        zero_log_dens -= max_log_dens;
        one_log_dens -= max_log_dens;
        var zero_prob = Math.exp(zero_log_dens - Math.log(Math.exp(zero_log_dens) + Math.exp(one_log_dens)));
        if (Math.random() < zero_prob) {
          this.state[this.param_name] = 0;
          return 0;
        } // else keep the param at 1 .
        return 1;
      };

      /**
      * @class
      * @implements {Stepper}
      * Just like MultidimComponentMetropolisStepper this Stepper takes a steps for
      * a multidimensional parameter by updating each component in turn. The difference
      * is that this stepper works on binary parameters.
      * @param params - An object with a single parameter definition for a 
      *   multidimensional parameter.
      * @param state - an object containing the state of all parameters.
      * @param log_post - A function that returns the log density that depends on the state. 
      * @param options - an object with options to the stepper.
      */
      var BinaryComponentStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        var param_names = Object.keys(this.params);
        if (param_names.length == 1) {
          this.param_name = param_names[0];
          var param = this.params[this.param_name];
          this.dim = param.dim;
        } else {
          throw "BinaryComponentStepper can't handle more than one parameter.";
        }
        var create_substeppers = function (dim, substate, log_post) {
          var substeppers = [];
          var i;
          if (dim.length === 1) {
            for (i = 0; i < dim[0]; i++) {
              var subparams = {};
              subparams[i] = param;
              substeppers[i] = new BinaryStepper(subparams, substate, log_post);
            }
          } else {
            for (i = 0; i < dim[0]; i++) {
              substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post);
            }
          }
          return substeppers;
        };
        this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post);
      };
      BinaryComponentStepper.prototype = Object.create(Stepper.prototype);
      BinaryComponentStepper.prototype.constructor = BinaryComponentStepper;
      BinaryComponentStepper.prototype.step = function () {
        // Go through the substeppers in a random order and call step() on them.
        return nested_array_random_apply(this.substeppers, function (substepper) {
          return substepper.step();
        });
      };

      /**
       * @class
       * @implements {Stepper}
       * This stepper can be responsible for taking a step for one or more parameters.
       * For real and int parameters it takes Metropolis within Gibbs steps, and for 
       * binary parameters it does evaluates the posterior for both paramter values and
       * randomly changes to a certain value proportionally to that value's posterior
       * (this is also done for each parameter, so also a * within Gibbs approach).
       * This stepper is also adaptive and can be efficient when the number of parameters
       * are not too high and the correlations between parameters are low.
       * @param params - An object with a one or more parameter definitions
       * @param state - an object containing the state of all parameters.
       * @param log_post - A function that returns the log density that depends on the state. 
       * @param options - an object with options to the stepper.
      */
      var AmwgStepper = function (params, state, log_post, options) {
        Stepper.call(this, params, state, log_post);
        this.param_names = Object.keys(this.params);
        this.substeppers = [];
        for (var i = 0; i < this.param_names.length; i++) {
          var param = params[this.param_names[i]];
          var SelectStepper;
          switch (param.type) {
            case "real":
              if (array_equal(param.dim, [1])) {
                SelectStepper = RealMetropolisStepper;
              } else {
                SelectStepper = MultiRealComponentMetropolisStepper;
              }
              break;
            case "int":
              if (array_equal(param.dim, [1])) {
                SelectStepper = IntMetropolisStepper;
              } else {
                SelectStepper = MultiIntComponentMetropolisStepper;
              }
              break;
            case "binary":
              if (array_equal(param.dim, [1])) {
                SelectStepper = BinaryStepper;
              } else {
                SelectStepper = BinaryComponentStepper;
              }
              break;
            default:
              throw "AmwgStepper can't handle parameter " + this.param_names[i] + " with type " + param.type;
          }
          var param_object_wrap = {};
          param_object_wrap[this.param_names[i]] = param;
          options = options || {};
          var param_options = options.params && options.params[this.param_names[i]] || {};
          param_options.prop_log_scale = param_options.prop_log_scale || options.prop_log_scale;
          param_options.batch_size = param_options.batch_size || options.batch_size;
          param_options.max_adaptation = param_options.max_adaptation || options.max_adaptation;
          param_options.initial_adaptation = param_options.initial_adaptation || options.initial_adaptation;
          param_options.target_accept_rate = param_options.target_accept_rate || options.target_accept_rate;
          param_options.is_adapting = param_options.is_adapting || options.is_adapting;
          this.substeppers[i] = new SelectStepper(param_object_wrap, state, log_post, param_options);
        }
      };
      AmwgStepper.prototype = Object.create(Stepper.prototype);
      AmwgStepper.prototype.constructor = AmwgStepper;
      AmwgStepper.prototype.step = function () {
        shuffle_array(this.substeppers);
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].step();
        }
        return this.state;
      };
      AmwgStepper.prototype.start_adaptation = function () {
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].start_adaptation();
        }
      };
      AmwgStepper.prototype.stop_adaptation = function () {
        for (var i = 0; i < this.substeppers.length; i++) {
          this.substeppers[i].stop_adaptation();
        }
      };
      AmwgStepper.prototype.info = function () {
        var info = {};
        for (var i = 0; i < this.substeppers.length; i++) {
          info[this.param_names[i]] = this.substeppers[i].info();
        }
        return info;
      };

      /////////// Sampler Functions //////////
      ////////////////////////////////////////

      /**
      * @interface
      * While you could fit a model by pasting together Steppers, a
      // Sampler is here is a convenience class where an instance of Sampler
      // sets up the Steppers, checks the parameter definition,
      // and manages the sampling. This here defines the Sampler "interface".
      * @interface
      * @param params - An object with parameter definitions, for example:
      *   {"mu": {"type": "real"}, "sigma": {"type": "real", "lower" = 0}}
      *   The parameter definitions doesn't have to be "complete" and properties
      *   left out (like lower and upper) will be filled in by defaults.
      * @param log_post - A function with signature function(state, data). Here
      *   state will be an object representing the state with each parameter as a 
      *   key and the parameter values as numbers or arrays. For example:
      *   {"mu": 3, "sigma": 1.5}. The data argument will be the same object as 
      *   the data argument given below.
      * @param data - an object that will be passed on to the log_post function
      *   when sampling.
      * @param options - an object with options to the sampler.
      */
      var Sampler = function (params, log_post, data, options) {
        this.params = params;
        this.data = data;
        this.param_names = Object.keys(this.params);

        // Setting default options if not passed through the options object
        this.param_init_fun = get_option("param_init_fun", options, param_init_fixed);
        var thinning_interval = get_option("thin", options, 1);
        var params_to_monitor = get_option("monitor", options, null);
        this.thin(thinning_interval);
        this.monitor(params_to_monitor);
        this.options = options;
        // Completing the params and initializing the state.
        this.params = complete_params(this.params, this.param_init_fun);
        var state = {};
        for (var i = 0; i < this.param_names.length; i++) {
          state[this.param_names[i]] = this.params[this.param_names[i]].init;
        }
        this.log_post = function () {
          return log_post(state, data);
        };
        // Running the log_post function once in case it further modifies the state
        // for example adding derived quantities.
        this.log_post();
        this.state = state;
        this.steppers = this.create_stepper_ensamble(this.params, this.state, this.log_post, this.options);
      };

      /** Should return a vector of steppers that when called 
       * should take a step in the parameter space.
       */
      Sampler.prototype.create_stepper_ensamble = function (state, log_post) {
        throw "Every Sampler needs to implement create_stepper_ensamble()";
      };

      /** Returns an object with info about the state of the Sampler.
       */
      Sampler.prototype.info = function () {
        return {
          state: this.state,
          thin: this.thin,
          monitor: this.monitor,
          steppers: this.steppers
        };
      };

      /** Takes a step in the parameter space. Returns the new space
       * but also modifies the state in place.
       */
      Sampler.prototype.step = function () {
        shuffle_array(this.steppers);
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].step();
        }
        if (Object.keys(this.state).length > Object.keys(this.params).length) {
          // The state contains devived quantities (not only parameters) and we
          // need to run the log_post once more in order to set the derived quantities
          // for the final parameter state
          this.log_post();
        }
        return this.state;
      };

      /**
       * Takes n_iterations steps in the parameter space and returns them
       * as an object of arrays with one array per parameter. For example:
       * {mu: [1, -1, 2, 3, ...], sigma: [1, 2, 2, 1, ...]}.
       * If thin is > 1 then n_iterations / thin samples are returned.
       */
      Sampler.prototype.sample = function (n_iterations) {
        // Initializing curr_sample where the sample is going to be saved
        // as an object containing one array per parameter to be monitored.
        var i, j, monitored_params;
        if (this.monitored_params === null) {
          monitored_params = Object.keys(this.state);
        } else {
          monitored_params = this.monitored_params;
        }
        var curr_sample = {};
        for (j = 0; j < monitored_params.length; j++) {
          curr_sample[monitored_params[j]] = [];
        }
        for (i = 0; i < n_iterations; i++) {
          if (i % this.thinning_interval === 0) {
            for (j = 0; j < monitored_params.length; j++) {
              var param = monitored_params[j];
              curr_sample[param].push(clone_param_draw(this.state[param]));
            }
          }
          this.step();
        }
        return curr_sample;
      };

      /**
       * Takes n_iteration steps in parameter space but returns nothing.
       */
      Sampler.prototype.burn = function (n_iterations) {
        for (var i = 0; i < n_iterations; i++) {
          this.step();
        }
      };

      /**
       * Sets what parameters should be monitored and returned when calling
       * sample.
       */
      Sampler.prototype.monitor = function (params_to_monitor) {
        this.monitored_params = params_to_monitor;
      };

      /**
       * Sets the thinning. For example thin == 10 means that every 10th posterior
       * draw will be kept.
       */
      Sampler.prototype.thin = function (thinning_interval) {
        this.thinning_interval = thinning_interval;
      };

      /**
       * Sets adaptation on, if applicable, in all steppers.
       */
      Sampler.prototype.start_adaptation = function () {
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].start_adaptation();
        }
      };

      /**
      * Sets adaptation off, if applicable, in all steppers.
      */
      Sampler.prototype.stop_adaptation = function () {
        for (var i = 0; i < this.steppers.length; i++) {
          this.steppers[i].stop_adaptation();
        }
      };

      /**
      * @class
      * @implements {Sampler}
      * This sampler uses the AmwgStepper as the stepper function which implements the 
      * Adaptive Metropolis-Within-Gibbs algorithm in "Examples of Adaptive MCMC"
      * by Roberts and Rosenthal (2008). An adition is that it handles int parameters
      * by making discrete Normal proposals and binary parameters by taking on a new 
      * value proportional to the posterior of the two possible states of the
      * parameter. This sampler can be efficient when the number of parameters
      * are not too high and the correlations between parameters are low.
      * @param params - An object with a one or more parameter definitions
      * @param state - an object containing the state of all parameters.
      * @param log_post - A function that returns the log density that depends on the state. 
      * @param options - an object with options to the stepper.
      */
      var AmwgSampler = function (params, log_post, data, options) {
        Sampler.call(this, params, log_post, data, options);
      };
      AmwgSampler.prototype = Object.create(Sampler.prototype);
      AmwgSampler.prototype.constructor = AmwgSampler;
      AmwgSampler.prototype.create_stepper_ensamble = function (params, state, log_post, options) {
        return [new AmwgStepper(params, state, log_post, options)];
      };

      // Returning the functions that should be publicly exposed by this module
      return {
        runif: runif,
        runif_discrete: runif_discrete,
        rnorm: rnorm,
        param_init_fixed: param_init_fixed,
        complete_params: complete_params,
        RealMetropolisStepper: RealMetropolisStepper,
        IntMetropolisStepper: IntMetropolisStepper,
        MultiRealComponentMetropolisStepper: MultiRealComponentMetropolisStepper,
        MultiIntComponentMetropolisStepper: MultiIntComponentMetropolisStepper,
        BinaryStepper: BinaryStepper,
        BinaryComponentStepper: BinaryComponentStepper,
        AmwgStepper: AmwgStepper,
        AmwgSampler: AmwgSampler
      };
    });
  })(mcmc$1);
  var mcmcExports = mcmc$1.exports;

  function ascending$1(a, b) {
    return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
  }

  function* numbers(values, valueof) {
    {
      for (let value of values) {
        if (value != null && (value = +value) >= value) {
          yield value;
        }
      }
    }
  }

  function compareDefined(compare = ascending$1) {
    if (compare === ascending$1) return ascendingDefined;
    if (typeof compare !== "function") throw new TypeError("compare is not a function");
    return (a, b) => {
      const x = compare(a, b);
      if (x || x === 0) return x;
      return (compare(b, b) === 0) - (compare(a, a) === 0);
    };
  }
  function ascendingDefined(a, b) {
    return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);
  }

  function max(values, valueof) {
    let max;
    {
      for (const value of values) {
        if (value != null && (max < value || max === undefined && value >= value)) {
          max = value;
        }
      }
    }
    return max;
  }

  function min(values, valueof) {
    let min;
    {
      for (const value of values) {
        if (value != null && (min > value || min === undefined && value >= value)) {
          min = value;
        }
      }
    }
    return min;
  }

  // Based on https://github.com/mourner/quickselect
  // ISC license, Copyright 2018 Vladimir Agafonkin.
  function quickselect(array, k, left = 0, right = Infinity, compare) {
    k = Math.floor(k);
    left = Math.floor(Math.max(0, left));
    right = Math.floor(Math.min(array.length - 1, right));
    if (!(left <= k && k <= right)) return array;
    compare = compare === undefined ? ascendingDefined : compareDefined(compare);
    while (right > left) {
      if (right - left > 600) {
        const n = right - left + 1;
        const m = k - left + 1;
        const z = Math.log(n);
        const s = 0.5 * Math.exp(2 * z / 3);
        const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);
        const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));
        const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));
        quickselect(array, k, newLeft, newRight, compare);
      }
      const t = array[k];
      let i = left;
      let j = right;
      swap(array, left, k);
      if (compare(array[right], t) > 0) swap(array, left, right);
      while (i < j) {
        swap(array, i, j), ++i, --j;
        while (compare(array[i], t) < 0) ++i;
        while (compare(array[j], t) > 0) --j;
      }
      if (compare(array[left], t) === 0) swap(array, left, j);else ++j, swap(array, j, right);
      if (j <= k) left = j + 1;
      if (k <= j) right = j - 1;
    }
    return array;
  }
  function swap(array, i, j) {
    const t = array[i];
    array[i] = array[j];
    array[j] = t;
  }

  function quantile(values, p, valueof) {
    values = Float64Array.from(numbers(values));
    if (!(n = values.length) || isNaN(p = +p)) return;
    if (p <= 0 || n < 2) return min(values);
    if (p >= 1) return max(values);
    var n,
      i = (n - 1) * p,
      i0 = Math.floor(i),
      value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),
      value1 = min(values.subarray(i0 + 1));
    return value0 + (value1 - value0) * (i - i0);
  }

  function median(values, valueof) {
    return quantile(values, 0.5);
  }

  var noop = {
    value: () => {}
  };
  function dispatch() {
    for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {
      if (!(t = arguments[i] + "") || t in _ || /[\s.]/.test(t)) throw new Error("illegal type: " + t);
      _[t] = [];
    }
    return new Dispatch(_);
  }
  function Dispatch(_) {
    this._ = _;
  }
  function parseTypenames$1(typenames, types) {
    return typenames.trim().split(/^|\s+/).map(function (t) {
      var name = "",
        i = t.indexOf(".");
      if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
      if (t && !types.hasOwnProperty(t)) throw new Error("unknown type: " + t);
      return {
        type: t,
        name: name
      };
    });
  }
  Dispatch.prototype = dispatch.prototype = {
    constructor: Dispatch,
    on: function (typename, callback) {
      var _ = this._,
        T = parseTypenames$1(typename + "", _),
        t,
        i = -1,
        n = T.length;

      // If no callback was specified, return the callback of the given type and name.
      if (arguments.length < 2) {
        while (++i < n) if ((t = (typename = T[i]).type) && (t = get$1(_[t], typename.name))) return t;
        return;
      }

      // If a type was specified, set the callback for the given type and name.
      // Otherwise, if a null callback was specified, remove callbacks of the given name.
      if (callback != null && typeof callback !== "function") throw new Error("invalid callback: " + callback);
      while (++i < n) {
        if (t = (typename = T[i]).type) _[t] = set$1(_[t], typename.name, callback);else if (callback == null) for (t in _) _[t] = set$1(_[t], typename.name, null);
      }
      return this;
    },
    copy: function () {
      var copy = {},
        _ = this._;
      for (var t in _) copy[t] = _[t].slice();
      return new Dispatch(copy);
    },
    call: function (type, that) {
      if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];
      if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
      for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
    },
    apply: function (type, that, args) {
      if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
      for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
    }
  };
  function get$1(type, name) {
    for (var i = 0, n = type.length, c; i < n; ++i) {
      if ((c = type[i]).name === name) {
        return c.value;
      }
    }
  }
  function set$1(type, name, callback) {
    for (var i = 0, n = type.length; i < n; ++i) {
      if (type[i].name === name) {
        type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));
        break;
      }
    }
    if (callback != null) type.push({
      name: name,
      value: callback
    });
    return type;
  }

  var xhtml = "http://www.w3.org/1999/xhtml";
  var namespaces = {
    svg: "http://www.w3.org/2000/svg",
    xhtml: xhtml,
    xlink: "http://www.w3.org/1999/xlink",
    xml: "http://www.w3.org/XML/1998/namespace",
    xmlns: "http://www.w3.org/2000/xmlns/"
  };

  function namespace (name) {
    var prefix = name += "",
      i = prefix.indexOf(":");
    if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);
    return namespaces.hasOwnProperty(prefix) ? {
      space: namespaces[prefix],
      local: name
    } : name; // eslint-disable-line no-prototype-builtins
  }

  function creatorInherit(name) {
    return function () {
      var document = this.ownerDocument,
        uri = this.namespaceURI;
      return uri === xhtml && document.documentElement.namespaceURI === xhtml ? document.createElement(name) : document.createElementNS(uri, name);
    };
  }
  function creatorFixed(fullname) {
    return function () {
      return this.ownerDocument.createElementNS(fullname.space, fullname.local);
    };
  }
  function creator (name) {
    var fullname = namespace(name);
    return (fullname.local ? creatorFixed : creatorInherit)(fullname);
  }

  function none() {}
  function selector (selector) {
    return selector == null ? none : function () {
      return this.querySelector(selector);
    };
  }

  function selection_select (select) {
    if (typeof select !== "function") select = selector(select);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
        if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
          if ("__data__" in node) subnode.__data__ = node.__data__;
          subgroup[i] = subnode;
        }
      }
    }
    return new Selection$1(subgroups, this._parents);
  }

  // Given something array like (or null), returns something that is strictly an
  // array. This is used to ensure that array-like objects passed to d3.selectAll
  // or selection.selectAll are converted into proper arrays when creating a
  // selection; we don’t ever want to create a selection backed by a live
  // HTMLCollection or NodeList. However, note that selection.selectAll will use a
  // static NodeList as a group, since it safely derived from querySelectorAll.
  function array(x) {
    return x == null ? [] : Array.isArray(x) ? x : Array.from(x);
  }

  function empty() {
    return [];
  }
  function selectorAll (selector) {
    return selector == null ? empty : function () {
      return this.querySelectorAll(selector);
    };
  }

  function arrayAll(select) {
    return function () {
      return array(select.apply(this, arguments));
    };
  }
  function selection_selectAll (select) {
    if (typeof select === "function") select = arrayAll(select);else select = selectorAll(select);
    for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          subgroups.push(select.call(node, node.__data__, i, group));
          parents.push(node);
        }
      }
    }
    return new Selection$1(subgroups, parents);
  }

  function matcher (selector) {
    return function () {
      return this.matches(selector);
    };
  }
  function childMatcher(selector) {
    return function (node) {
      return node.matches(selector);
    };
  }

  var find = Array.prototype.find;
  function childFind(match) {
    return function () {
      return find.call(this.children, match);
    };
  }
  function childFirst() {
    return this.firstElementChild;
  }
  function selection_selectChild (match) {
    return this.select(match == null ? childFirst : childFind(typeof match === "function" ? match : childMatcher(match)));
  }

  var filter = Array.prototype.filter;
  function children() {
    return Array.from(this.children);
  }
  function childrenFilter(match) {
    return function () {
      return filter.call(this.children, match);
    };
  }
  function selection_selectChildren (match) {
    return this.selectAll(match == null ? children : childrenFilter(typeof match === "function" ? match : childMatcher(match)));
  }

  function selection_filter (match) {
    if (typeof match !== "function") match = matcher(match);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
        if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
          subgroup.push(node);
        }
      }
    }
    return new Selection$1(subgroups, this._parents);
  }

  function sparse (update) {
    return new Array(update.length);
  }

  function selection_enter () {
    return new Selection$1(this._enter || this._groups.map(sparse), this._parents);
  }
  function EnterNode(parent, datum) {
    this.ownerDocument = parent.ownerDocument;
    this.namespaceURI = parent.namespaceURI;
    this._next = null;
    this._parent = parent;
    this.__data__ = datum;
  }
  EnterNode.prototype = {
    constructor: EnterNode,
    appendChild: function (child) {
      return this._parent.insertBefore(child, this._next);
    },
    insertBefore: function (child, next) {
      return this._parent.insertBefore(child, next);
    },
    querySelector: function (selector) {
      return this._parent.querySelector(selector);
    },
    querySelectorAll: function (selector) {
      return this._parent.querySelectorAll(selector);
    }
  };

  function constant$1 (x) {
    return function () {
      return x;
    };
  }

  function bindIndex(parent, group, enter, update, exit, data) {
    var i = 0,
      node,
      groupLength = group.length,
      dataLength = data.length;

    // Put any non-null nodes that fit into update.
    // Put any null nodes into enter.
    // Put any remaining data into enter.
    for (; i < dataLength; ++i) {
      if (node = group[i]) {
        node.__data__ = data[i];
        update[i] = node;
      } else {
        enter[i] = new EnterNode(parent, data[i]);
      }
    }

    // Put any non-null nodes that don’t fit into exit.
    for (; i < groupLength; ++i) {
      if (node = group[i]) {
        exit[i] = node;
      }
    }
  }
  function bindKey(parent, group, enter, update, exit, data, key) {
    var i,
      node,
      nodeByKeyValue = new Map(),
      groupLength = group.length,
      dataLength = data.length,
      keyValues = new Array(groupLength),
      keyValue;

    // Compute the key for each node.
    // If multiple nodes have the same key, the duplicates are added to exit.
    for (i = 0; i < groupLength; ++i) {
      if (node = group[i]) {
        keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + "";
        if (nodeByKeyValue.has(keyValue)) {
          exit[i] = node;
        } else {
          nodeByKeyValue.set(keyValue, node);
        }
      }
    }

    // Compute the key for each datum.
    // If there a node associated with this key, join and add it to update.
    // If there is not (or the key is a duplicate), add it to enter.
    for (i = 0; i < dataLength; ++i) {
      keyValue = key.call(parent, data[i], i, data) + "";
      if (node = nodeByKeyValue.get(keyValue)) {
        update[i] = node;
        node.__data__ = data[i];
        nodeByKeyValue.delete(keyValue);
      } else {
        enter[i] = new EnterNode(parent, data[i]);
      }
    }

    // Add any remaining nodes that were not bound to data to exit.
    for (i = 0; i < groupLength; ++i) {
      if ((node = group[i]) && nodeByKeyValue.get(keyValues[i]) === node) {
        exit[i] = node;
      }
    }
  }
  function datum(node) {
    return node.__data__;
  }
  function selection_data (value, key) {
    if (!arguments.length) return Array.from(this, datum);
    var bind = key ? bindKey : bindIndex,
      parents = this._parents,
      groups = this._groups;
    if (typeof value !== "function") value = constant$1(value);
    for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {
      var parent = parents[j],
        group = groups[j],
        groupLength = group.length,
        data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),
        dataLength = data.length,
        enterGroup = enter[j] = new Array(dataLength),
        updateGroup = update[j] = new Array(dataLength),
        exitGroup = exit[j] = new Array(groupLength);
      bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);

      // Now connect the enter nodes to their following update node, such that
      // appendChild can insert the materialized enter node before this node,
      // rather than at the end of the parent node.
      for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {
        if (previous = enterGroup[i0]) {
          if (i0 >= i1) i1 = i0 + 1;
          while (!(next = updateGroup[i1]) && ++i1 < dataLength);
          previous._next = next || null;
        }
      }
    }
    update = new Selection$1(update, parents);
    update._enter = enter;
    update._exit = exit;
    return update;
  }

  // Given some data, this returns an array-like view of it: an object that
  // exposes a length property and allows numeric indexing. Note that unlike
  // selectAll, this isn’t worried about “live” collections because the resulting
  // array will only be used briefly while data is being bound. (It is possible to
  // cause the data to change while iterating by using a key function, but please
  // don’t; we’d rather avoid a gratuitous copy.)
  function arraylike(data) {
    return typeof data === "object" && "length" in data ? data // Array, TypedArray, NodeList, array-like
    : Array.from(data); // Map, Set, iterable, string, or anything else
  }

  function selection_exit () {
    return new Selection$1(this._exit || this._groups.map(sparse), this._parents);
  }

  function selection_join (onenter, onupdate, onexit) {
    var enter = this.enter(),
      update = this,
      exit = this.exit();
    if (typeof onenter === "function") {
      enter = onenter(enter);
      if (enter) enter = enter.selection();
    } else {
      enter = enter.append(onenter + "");
    }
    if (onupdate != null) {
      update = onupdate(update);
      if (update) update = update.selection();
    }
    if (onexit == null) exit.remove();else onexit(exit);
    return enter && update ? enter.merge(update).order() : update;
  }

  function selection_merge (context) {
    var selection = context.selection ? context.selection() : context;
    for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
      for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group0[i] || group1[i]) {
          merge[i] = node;
        }
      }
    }
    for (; j < m0; ++j) {
      merges[j] = groups0[j];
    }
    return new Selection$1(merges, this._parents);
  }

  function selection_order () {
    for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {
      for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {
        if (node = group[i]) {
          if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);
          next = node;
        }
      }
    }
    return this;
  }

  function selection_sort (compare) {
    if (!compare) compare = ascending;
    function compareNode(a, b) {
      return a && b ? compare(a.__data__, b.__data__) : !a - !b;
    }
    for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          sortgroup[i] = node;
        }
      }
      sortgroup.sort(compareNode);
    }
    return new Selection$1(sortgroups, this._parents).order();
  }
  function ascending(a, b) {
    return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
  }

  function selection_call () {
    var callback = arguments[0];
    arguments[0] = this;
    callback.apply(null, arguments);
    return this;
  }

  function selection_nodes () {
    return Array.from(this);
  }

  function selection_node () {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {
        var node = group[i];
        if (node) return node;
      }
    }
    return null;
  }

  function selection_size () {
    let size = 0;
    for (const node of this) ++size; // eslint-disable-line no-unused-vars
    return size;
  }

  function selection_empty () {
    return !this.node();
  }

  function selection_each (callback) {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
        if (node = group[i]) callback.call(node, node.__data__, i, group);
      }
    }
    return this;
  }

  function attrRemove$1(name) {
    return function () {
      this.removeAttribute(name);
    };
  }
  function attrRemoveNS$1(fullname) {
    return function () {
      this.removeAttributeNS(fullname.space, fullname.local);
    };
  }
  function attrConstant$1(name, value) {
    return function () {
      this.setAttribute(name, value);
    };
  }
  function attrConstantNS$1(fullname, value) {
    return function () {
      this.setAttributeNS(fullname.space, fullname.local, value);
    };
  }
  function attrFunction$1(name, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.removeAttribute(name);else this.setAttribute(name, v);
    };
  }
  function attrFunctionNS$1(fullname, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.removeAttributeNS(fullname.space, fullname.local);else this.setAttributeNS(fullname.space, fullname.local, v);
    };
  }
  function selection_attr (name, value) {
    var fullname = namespace(name);
    if (arguments.length < 2) {
      var node = this.node();
      return fullname.local ? node.getAttributeNS(fullname.space, fullname.local) : node.getAttribute(fullname);
    }
    return this.each((value == null ? fullname.local ? attrRemoveNS$1 : attrRemove$1 : typeof value === "function" ? fullname.local ? attrFunctionNS$1 : attrFunction$1 : fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, value));
  }

  function defaultView (node) {
    return node.ownerDocument && node.ownerDocument.defaultView // node is a Node
    || node.document && node // node is a Window
    || node.defaultView; // node is a Document
  }

  function styleRemove$1(name) {
    return function () {
      this.style.removeProperty(name);
    };
  }
  function styleConstant$1(name, value, priority) {
    return function () {
      this.style.setProperty(name, value, priority);
    };
  }
  function styleFunction$1(name, value, priority) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) this.style.removeProperty(name);else this.style.setProperty(name, v, priority);
    };
  }
  function selection_style (name, value, priority) {
    return arguments.length > 1 ? this.each((value == null ? styleRemove$1 : typeof value === "function" ? styleFunction$1 : styleConstant$1)(name, value, priority == null ? "" : priority)) : styleValue(this.node(), name);
  }
  function styleValue(node, name) {
    return node.style.getPropertyValue(name) || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);
  }

  function propertyRemove(name) {
    return function () {
      delete this[name];
    };
  }
  function propertyConstant(name, value) {
    return function () {
      this[name] = value;
    };
  }
  function propertyFunction(name, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (v == null) delete this[name];else this[name] = v;
    };
  }
  function selection_property (name, value) {
    return arguments.length > 1 ? this.each((value == null ? propertyRemove : typeof value === "function" ? propertyFunction : propertyConstant)(name, value)) : this.node()[name];
  }

  function classArray(string) {
    return string.trim().split(/^|\s+/);
  }
  function classList(node) {
    return node.classList || new ClassList(node);
  }
  function ClassList(node) {
    this._node = node;
    this._names = classArray(node.getAttribute("class") || "");
  }
  ClassList.prototype = {
    add: function (name) {
      var i = this._names.indexOf(name);
      if (i < 0) {
        this._names.push(name);
        this._node.setAttribute("class", this._names.join(" "));
      }
    },
    remove: function (name) {
      var i = this._names.indexOf(name);
      if (i >= 0) {
        this._names.splice(i, 1);
        this._node.setAttribute("class", this._names.join(" "));
      }
    },
    contains: function (name) {
      return this._names.indexOf(name) >= 0;
    }
  };
  function classedAdd(node, names) {
    var list = classList(node),
      i = -1,
      n = names.length;
    while (++i < n) list.add(names[i]);
  }
  function classedRemove(node, names) {
    var list = classList(node),
      i = -1,
      n = names.length;
    while (++i < n) list.remove(names[i]);
  }
  function classedTrue(names) {
    return function () {
      classedAdd(this, names);
    };
  }
  function classedFalse(names) {
    return function () {
      classedRemove(this, names);
    };
  }
  function classedFunction(names, value) {
    return function () {
      (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);
    };
  }
  function selection_classed (name, value) {
    var names = classArray(name + "");
    if (arguments.length < 2) {
      var list = classList(this.node()),
        i = -1,
        n = names.length;
      while (++i < n) if (!list.contains(names[i])) return false;
      return true;
    }
    return this.each((typeof value === "function" ? classedFunction : value ? classedTrue : classedFalse)(names, value));
  }

  function textRemove() {
    this.textContent = "";
  }
  function textConstant$1(value) {
    return function () {
      this.textContent = value;
    };
  }
  function textFunction$1(value) {
    return function () {
      var v = value.apply(this, arguments);
      this.textContent = v == null ? "" : v;
    };
  }
  function selection_text (value) {
    return arguments.length ? this.each(value == null ? textRemove : (typeof value === "function" ? textFunction$1 : textConstant$1)(value)) : this.node().textContent;
  }

  function htmlRemove() {
    this.innerHTML = "";
  }
  function htmlConstant(value) {
    return function () {
      this.innerHTML = value;
    };
  }
  function htmlFunction(value) {
    return function () {
      var v = value.apply(this, arguments);
      this.innerHTML = v == null ? "" : v;
    };
  }
  function selection_html (value) {
    return arguments.length ? this.each(value == null ? htmlRemove : (typeof value === "function" ? htmlFunction : htmlConstant)(value)) : this.node().innerHTML;
  }

  function raise() {
    if (this.nextSibling) this.parentNode.appendChild(this);
  }
  function selection_raise () {
    return this.each(raise);
  }

  function lower() {
    if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);
  }
  function selection_lower () {
    return this.each(lower);
  }

  function selection_append (name) {
    var create = typeof name === "function" ? name : creator(name);
    return this.select(function () {
      return this.appendChild(create.apply(this, arguments));
    });
  }

  function constantNull() {
    return null;
  }
  function selection_insert (name, before) {
    var create = typeof name === "function" ? name : creator(name),
      select = before == null ? constantNull : typeof before === "function" ? before : selector(before);
    return this.select(function () {
      return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);
    });
  }

  function remove() {
    var parent = this.parentNode;
    if (parent) parent.removeChild(this);
  }
  function selection_remove () {
    return this.each(remove);
  }

  function selection_cloneShallow() {
    var clone = this.cloneNode(false),
      parent = this.parentNode;
    return parent ? parent.insertBefore(clone, this.nextSibling) : clone;
  }
  function selection_cloneDeep() {
    var clone = this.cloneNode(true),
      parent = this.parentNode;
    return parent ? parent.insertBefore(clone, this.nextSibling) : clone;
  }
  function selection_clone (deep) {
    return this.select(deep ? selection_cloneDeep : selection_cloneShallow);
  }

  function selection_datum (value) {
    return arguments.length ? this.property("__data__", value) : this.node().__data__;
  }

  function contextListener(listener) {
    return function (event) {
      listener.call(this, event, this.__data__);
    };
  }
  function parseTypenames(typenames) {
    return typenames.trim().split(/^|\s+/).map(function (t) {
      var name = "",
        i = t.indexOf(".");
      if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
      return {
        type: t,
        name: name
      };
    });
  }
  function onRemove(typename) {
    return function () {
      var on = this.__on;
      if (!on) return;
      for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {
        if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {
          this.removeEventListener(o.type, o.listener, o.options);
        } else {
          on[++i] = o;
        }
      }
      if (++i) on.length = i;else delete this.__on;
    };
  }
  function onAdd(typename, value, options) {
    return function () {
      var on = this.__on,
        o,
        listener = contextListener(value);
      if (on) for (var j = 0, m = on.length; j < m; ++j) {
        if ((o = on[j]).type === typename.type && o.name === typename.name) {
          this.removeEventListener(o.type, o.listener, o.options);
          this.addEventListener(o.type, o.listener = listener, o.options = options);
          o.value = value;
          return;
        }
      }
      this.addEventListener(typename.type, listener, options);
      o = {
        type: typename.type,
        name: typename.name,
        value: value,
        listener: listener,
        options: options
      };
      if (!on) this.__on = [o];else on.push(o);
    };
  }
  function selection_on (typename, value, options) {
    var typenames = parseTypenames(typename + ""),
      i,
      n = typenames.length,
      t;
    if (arguments.length < 2) {
      var on = this.node().__on;
      if (on) for (var j = 0, m = on.length, o; j < m; ++j) {
        for (i = 0, o = on[j]; i < n; ++i) {
          if ((t = typenames[i]).type === o.type && t.name === o.name) {
            return o.value;
          }
        }
      }
      return;
    }
    on = value ? onAdd : onRemove;
    for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));
    return this;
  }

  function dispatchEvent(node, type, params) {
    var window = defaultView(node),
      event = window.CustomEvent;
    if (typeof event === "function") {
      event = new event(type, params);
    } else {
      event = window.document.createEvent("Event");
      if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;else event.initEvent(type, false, false);
    }
    node.dispatchEvent(event);
  }
  function dispatchConstant(type, params) {
    return function () {
      return dispatchEvent(this, type, params);
    };
  }
  function dispatchFunction(type, params) {
    return function () {
      return dispatchEvent(this, type, params.apply(this, arguments));
    };
  }
  function selection_dispatch (type, params) {
    return this.each((typeof params === "function" ? dispatchFunction : dispatchConstant)(type, params));
  }

  function* selection_iterator () {
    for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
      for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
        if (node = group[i]) yield node;
      }
    }
  }

  var root = [null];
  function Selection$1(groups, parents) {
    this._groups = groups;
    this._parents = parents;
  }
  function selection() {
    return new Selection$1([[document.documentElement]], root);
  }
  function selection_selection() {
    return this;
  }
  Selection$1.prototype = selection.prototype = {
    constructor: Selection$1,
    select: selection_select,
    selectAll: selection_selectAll,
    selectChild: selection_selectChild,
    selectChildren: selection_selectChildren,
    filter: selection_filter,
    data: selection_data,
    enter: selection_enter,
    exit: selection_exit,
    join: selection_join,
    merge: selection_merge,
    selection: selection_selection,
    order: selection_order,
    sort: selection_sort,
    call: selection_call,
    nodes: selection_nodes,
    node: selection_node,
    size: selection_size,
    empty: selection_empty,
    each: selection_each,
    attr: selection_attr,
    style: selection_style,
    property: selection_property,
    classed: selection_classed,
    text: selection_text,
    html: selection_html,
    raise: selection_raise,
    lower: selection_lower,
    append: selection_append,
    insert: selection_insert,
    remove: selection_remove,
    clone: selection_clone,
    datum: selection_datum,
    on: selection_on,
    dispatch: selection_dispatch,
    [Symbol.iterator]: selection_iterator
  };

  function define (constructor, factory, prototype) {
    constructor.prototype = factory.prototype = prototype;
    prototype.constructor = constructor;
  }
  function extend(parent, definition) {
    var prototype = Object.create(parent.prototype);
    for (var key in definition) prototype[key] = definition[key];
    return prototype;
  }

  function Color() {}
  var darker = 0.7;
  var brighter = 1 / darker;
  var reI = "\\s*([+-]?\\d+)\\s*",
    reN = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",
    reP = "\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",
    reHex = /^#([0-9a-f]{3,8})$/,
    reRgbInteger = new RegExp(`^rgb\\(${reI},${reI},${reI}\\)$`),
    reRgbPercent = new RegExp(`^rgb\\(${reP},${reP},${reP}\\)$`),
    reRgbaInteger = new RegExp(`^rgba\\(${reI},${reI},${reI},${reN}\\)$`),
    reRgbaPercent = new RegExp(`^rgba\\(${reP},${reP},${reP},${reN}\\)$`),
    reHslPercent = new RegExp(`^hsl\\(${reN},${reP},${reP}\\)$`),
    reHslaPercent = new RegExp(`^hsla\\(${reN},${reP},${reP},${reN}\\)$`);
  var named = {
    aliceblue: 0xf0f8ff,
    antiquewhite: 0xfaebd7,
    aqua: 0x00ffff,
    aquamarine: 0x7fffd4,
    azure: 0xf0ffff,
    beige: 0xf5f5dc,
    bisque: 0xffe4c4,
    black: 0x000000,
    blanchedalmond: 0xffebcd,
    blue: 0x0000ff,
    blueviolet: 0x8a2be2,
    brown: 0xa52a2a,
    burlywood: 0xdeb887,
    cadetblue: 0x5f9ea0,
    chartreuse: 0x7fff00,
    chocolate: 0xd2691e,
    coral: 0xff7f50,
    cornflowerblue: 0x6495ed,
    cornsilk: 0xfff8dc,
    crimson: 0xdc143c,
    cyan: 0x00ffff,
    darkblue: 0x00008b,
    darkcyan: 0x008b8b,
    darkgoldenrod: 0xb8860b,
    darkgray: 0xa9a9a9,
    darkgreen: 0x006400,
    darkgrey: 0xa9a9a9,
    darkkhaki: 0xbdb76b,
    darkmagenta: 0x8b008b,
    darkolivegreen: 0x556b2f,
    darkorange: 0xff8c00,
    darkorchid: 0x9932cc,
    darkred: 0x8b0000,
    darksalmon: 0xe9967a,
    darkseagreen: 0x8fbc8f,
    darkslateblue: 0x483d8b,
    darkslategray: 0x2f4f4f,
    darkslategrey: 0x2f4f4f,
    darkturquoise: 0x00ced1,
    darkviolet: 0x9400d3,
    deeppink: 0xff1493,
    deepskyblue: 0x00bfff,
    dimgray: 0x696969,
    dimgrey: 0x696969,
    dodgerblue: 0x1e90ff,
    firebrick: 0xb22222,
    floralwhite: 0xfffaf0,
    forestgreen: 0x228b22,
    fuchsia: 0xff00ff,
    gainsboro: 0xdcdcdc,
    ghostwhite: 0xf8f8ff,
    gold: 0xffd700,
    goldenrod: 0xdaa520,
    gray: 0x808080,
    green: 0x008000,
    greenyellow: 0xadff2f,
    grey: 0x808080,
    honeydew: 0xf0fff0,
    hotpink: 0xff69b4,
    indianred: 0xcd5c5c,
    indigo: 0x4b0082,
    ivory: 0xfffff0,
    khaki: 0xf0e68c,
    lavender: 0xe6e6fa,
    lavenderblush: 0xfff0f5,
    lawngreen: 0x7cfc00,
    lemonchiffon: 0xfffacd,
    lightblue: 0xadd8e6,
    lightcoral: 0xf08080,
    lightcyan: 0xe0ffff,
    lightgoldenrodyellow: 0xfafad2,
    lightgray: 0xd3d3d3,
    lightgreen: 0x90ee90,
    lightgrey: 0xd3d3d3,
    lightpink: 0xffb6c1,
    lightsalmon: 0xffa07a,
    lightseagreen: 0x20b2aa,
    lightskyblue: 0x87cefa,
    lightslategray: 0x778899,
    lightslategrey: 0x778899,
    lightsteelblue: 0xb0c4de,
    lightyellow: 0xffffe0,
    lime: 0x00ff00,
    limegreen: 0x32cd32,
    linen: 0xfaf0e6,
    magenta: 0xff00ff,
    maroon: 0x800000,
    mediumaquamarine: 0x66cdaa,
    mediumblue: 0x0000cd,
    mediumorchid: 0xba55d3,
    mediumpurple: 0x9370db,
    mediumseagreen: 0x3cb371,
    mediumslateblue: 0x7b68ee,
    mediumspringgreen: 0x00fa9a,
    mediumturquoise: 0x48d1cc,
    mediumvioletred: 0xc71585,
    midnightblue: 0x191970,
    mintcream: 0xf5fffa,
    mistyrose: 0xffe4e1,
    moccasin: 0xffe4b5,
    navajowhite: 0xffdead,
    navy: 0x000080,
    oldlace: 0xfdf5e6,
    olive: 0x808000,
    olivedrab: 0x6b8e23,
    orange: 0xffa500,
    orangered: 0xff4500,
    orchid: 0xda70d6,
    palegoldenrod: 0xeee8aa,
    palegreen: 0x98fb98,
    paleturquoise: 0xafeeee,
    palevioletred: 0xdb7093,
    papayawhip: 0xffefd5,
    peachpuff: 0xffdab9,
    peru: 0xcd853f,
    pink: 0xffc0cb,
    plum: 0xdda0dd,
    powderblue: 0xb0e0e6,
    purple: 0x800080,
    rebeccapurple: 0x663399,
    red: 0xff0000,
    rosybrown: 0xbc8f8f,
    royalblue: 0x4169e1,
    saddlebrown: 0x8b4513,
    salmon: 0xfa8072,
    sandybrown: 0xf4a460,
    seagreen: 0x2e8b57,
    seashell: 0xfff5ee,
    sienna: 0xa0522d,
    silver: 0xc0c0c0,
    skyblue: 0x87ceeb,
    slateblue: 0x6a5acd,
    slategray: 0x708090,
    slategrey: 0x708090,
    snow: 0xfffafa,
    springgreen: 0x00ff7f,
    steelblue: 0x4682b4,
    tan: 0xd2b48c,
    teal: 0x008080,
    thistle: 0xd8bfd8,
    tomato: 0xff6347,
    turquoise: 0x40e0d0,
    violet: 0xee82ee,
    wheat: 0xf5deb3,
    white: 0xffffff,
    whitesmoke: 0xf5f5f5,
    yellow: 0xffff00,
    yellowgreen: 0x9acd32
  };
  define(Color, color, {
    copy(channels) {
      return Object.assign(new this.constructor(), this, channels);
    },
    displayable() {
      return this.rgb().displayable();
    },
    hex: color_formatHex,
    // Deprecated! Use color.formatHex.
    formatHex: color_formatHex,
    formatHex8: color_formatHex8,
    formatHsl: color_formatHsl,
    formatRgb: color_formatRgb,
    toString: color_formatRgb
  });
  function color_formatHex() {
    return this.rgb().formatHex();
  }
  function color_formatHex8() {
    return this.rgb().formatHex8();
  }
  function color_formatHsl() {
    return hslConvert(this).formatHsl();
  }
  function color_formatRgb() {
    return this.rgb().formatRgb();
  }
  function color(format) {
    var m, l;
    format = (format + "").trim().toLowerCase();
    return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000
    : l === 3 ? new Rgb(m >> 8 & 0xf | m >> 4 & 0xf0, m >> 4 & 0xf | m & 0xf0, (m & 0xf) << 4 | m & 0xf, 1) // #f00
    : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000
    : l === 4 ? rgba(m >> 12 & 0xf | m >> 8 & 0xf0, m >> 8 & 0xf | m >> 4 & 0xf0, m >> 4 & 0xf | m & 0xf0, ((m & 0xf) << 4 | m & 0xf) / 0xff) // #f000
    : null // invalid hex
    ) : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)
    : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)
    : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)
    : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)
    : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)
    : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)
    : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins
    : format === "transparent" ? new Rgb(NaN, NaN, NaN, 0) : null;
  }
  function rgbn(n) {
    return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);
  }
  function rgba(r, g, b, a) {
    if (a <= 0) r = g = b = NaN;
    return new Rgb(r, g, b, a);
  }
  function rgbConvert(o) {
    if (!(o instanceof Color)) o = color(o);
    if (!o) return new Rgb();
    o = o.rgb();
    return new Rgb(o.r, o.g, o.b, o.opacity);
  }
  function rgb(r, g, b, opacity) {
    return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);
  }
  function Rgb(r, g, b, opacity) {
    this.r = +r;
    this.g = +g;
    this.b = +b;
    this.opacity = +opacity;
  }
  define(Rgb, rgb, extend(Color, {
    brighter(k) {
      k = k == null ? brighter : Math.pow(brighter, k);
      return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
    },
    darker(k) {
      k = k == null ? darker : Math.pow(darker, k);
      return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
    },
    rgb() {
      return this;
    },
    clamp() {
      return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));
    },
    displayable() {
      return -0.5 <= this.r && this.r < 255.5 && -0.5 <= this.g && this.g < 255.5 && -0.5 <= this.b && this.b < 255.5 && 0 <= this.opacity && this.opacity <= 1;
    },
    hex: rgb_formatHex,
    // Deprecated! Use color.formatHex.
    formatHex: rgb_formatHex,
    formatHex8: rgb_formatHex8,
    formatRgb: rgb_formatRgb,
    toString: rgb_formatRgb
  }));
  function rgb_formatHex() {
    return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;
  }
  function rgb_formatHex8() {
    return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;
  }
  function rgb_formatRgb() {
    const a = clampa(this.opacity);
    return `${a === 1 ? "rgb(" : "rgba("}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? ")" : `, ${a})`}`;
  }
  function clampa(opacity) {
    return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));
  }
  function clampi(value) {
    return Math.max(0, Math.min(255, Math.round(value) || 0));
  }
  function hex(value) {
    value = clampi(value);
    return (value < 16 ? "0" : "") + value.toString(16);
  }
  function hsla(h, s, l, a) {
    if (a <= 0) h = s = l = NaN;else if (l <= 0 || l >= 1) h = s = NaN;else if (s <= 0) h = NaN;
    return new Hsl(h, s, l, a);
  }
  function hslConvert(o) {
    if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);
    if (!(o instanceof Color)) o = color(o);
    if (!o) return new Hsl();
    if (o instanceof Hsl) return o;
    o = o.rgb();
    var r = o.r / 255,
      g = o.g / 255,
      b = o.b / 255,
      min = Math.min(r, g, b),
      max = Math.max(r, g, b),
      h = NaN,
      s = max - min,
      l = (max + min) / 2;
    if (s) {
      if (r === max) h = (g - b) / s + (g < b) * 6;else if (g === max) h = (b - r) / s + 2;else h = (r - g) / s + 4;
      s /= l < 0.5 ? max + min : 2 - max - min;
      h *= 60;
    } else {
      s = l > 0 && l < 1 ? 0 : h;
    }
    return new Hsl(h, s, l, o.opacity);
  }
  function hsl(h, s, l, opacity) {
    return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);
  }
  function Hsl(h, s, l, opacity) {
    this.h = +h;
    this.s = +s;
    this.l = +l;
    this.opacity = +opacity;
  }
  define(Hsl, hsl, extend(Color, {
    brighter(k) {
      k = k == null ? brighter : Math.pow(brighter, k);
      return new Hsl(this.h, this.s, this.l * k, this.opacity);
    },
    darker(k) {
      k = k == null ? darker : Math.pow(darker, k);
      return new Hsl(this.h, this.s, this.l * k, this.opacity);
    },
    rgb() {
      var h = this.h % 360 + (this.h < 0) * 360,
        s = isNaN(h) || isNaN(this.s) ? 0 : this.s,
        l = this.l,
        m2 = l + (l < 0.5 ? l : 1 - l) * s,
        m1 = 2 * l - m2;
      return new Rgb(hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2), hsl2rgb(h, m1, m2), hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2), this.opacity);
    },
    clamp() {
      return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));
    },
    displayable() {
      return (0 <= this.s && this.s <= 1 || isNaN(this.s)) && 0 <= this.l && this.l <= 1 && 0 <= this.opacity && this.opacity <= 1;
    },
    formatHsl() {
      const a = clampa(this.opacity);
      return `${a === 1 ? "hsl(" : "hsla("}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? ")" : `, ${a})`}`;
    }
  }));
  function clamph(value) {
    value = (value || 0) % 360;
    return value < 0 ? value + 360 : value;
  }
  function clampt(value) {
    return Math.max(0, Math.min(1, value || 0));
  }

  /* From FvD 13.37, CSS Color Module Level 3 */
  function hsl2rgb(h, m1, m2) {
    return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255;
  }

  var constant = x => () => x;

  function linear(a, d) {
    return function (t) {
      return a + t * d;
    };
  }
  function exponential(a, b, y) {
    return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function (t) {
      return Math.pow(a + t * b, y);
    };
  }
  function gamma(y) {
    return (y = +y) === 1 ? nogamma : function (a, b) {
      return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);
    };
  }
  function nogamma(a, b) {
    var d = b - a;
    return d ? linear(a, d) : constant(isNaN(a) ? b : a);
  }

  var interpolateRgb = (function rgbGamma(y) {
    var color = gamma(y);
    function rgb$1(start, end) {
      var r = color((start = rgb(start)).r, (end = rgb(end)).r),
        g = color(start.g, end.g),
        b = color(start.b, end.b),
        opacity = nogamma(start.opacity, end.opacity);
      return function (t) {
        start.r = r(t);
        start.g = g(t);
        start.b = b(t);
        start.opacity = opacity(t);
        return start + "";
      };
    }
    rgb$1.gamma = rgbGamma;
    return rgb$1;
  })(1);

  function interpolateNumber (a, b) {
    return a = +a, b = +b, function (t) {
      return a * (1 - t) + b * t;
    };
  }

  var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,
    reB = new RegExp(reA.source, "g");
  function zero(b) {
    return function () {
      return b;
    };
  }
  function one(b) {
    return function (t) {
      return b(t) + "";
    };
  }
  function interpolateString (a, b) {
    var bi = reA.lastIndex = reB.lastIndex = 0,
      // scan index for next number in b
      am,
      // current match in a
      bm,
      // current match in b
      bs,
      // string preceding current number in b, if any
      i = -1,
      // index in s
      s = [],
      // string constants and placeholders
      q = []; // number interpolators

    // Coerce inputs to strings.
    a = a + "", b = b + "";

    // Interpolate pairs of numbers in a & b.
    while ((am = reA.exec(a)) && (bm = reB.exec(b))) {
      if ((bs = bm.index) > bi) {
        // a string precedes the next number in b
        bs = b.slice(bi, bs);
        if (s[i]) s[i] += bs; // coalesce with previous string
        else s[++i] = bs;
      }
      if ((am = am[0]) === (bm = bm[0])) {
        // numbers in a & b match
        if (s[i]) s[i] += bm; // coalesce with previous string
        else s[++i] = bm;
      } else {
        // interpolate non-matching numbers
        s[++i] = null;
        q.push({
          i: i,
          x: interpolateNumber(am, bm)
        });
      }
      bi = reB.lastIndex;
    }

    // Add remains of b.
    if (bi < b.length) {
      bs = b.slice(bi);
      if (s[i]) s[i] += bs; // coalesce with previous string
      else s[++i] = bs;
    }

    // Special optimization for only a single match.
    // Otherwise, interpolate each of the numbers and rejoin the string.
    return s.length < 2 ? q[0] ? one(q[0].x) : zero(b) : (b = q.length, function (t) {
      for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);
      return s.join("");
    });
  }

  var degrees = 180 / Math.PI;
  var identity = {
    translateX: 0,
    translateY: 0,
    rotate: 0,
    skewX: 0,
    scaleX: 1,
    scaleY: 1
  };
  function decompose (a, b, c, d, e, f) {
    var scaleX, scaleY, skewX;
    if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;
    if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;
    if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;
    if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;
    return {
      translateX: e,
      translateY: f,
      rotate: Math.atan2(b, a) * degrees,
      skewX: Math.atan(skewX) * degrees,
      scaleX: scaleX,
      scaleY: scaleY
    };
  }

  var svgNode;

  /* eslint-disable no-undef */
  function parseCss(value) {
    const m = new (typeof DOMMatrix === "function" ? DOMMatrix : WebKitCSSMatrix)(value + "");
    return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);
  }
  function parseSvg(value) {
    if (value == null) return identity;
    if (!svgNode) svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g");
    svgNode.setAttribute("transform", value);
    if (!(value = svgNode.transform.baseVal.consolidate())) return identity;
    value = value.matrix;
    return decompose(value.a, value.b, value.c, value.d, value.e, value.f);
  }

  function interpolateTransform(parse, pxComma, pxParen, degParen) {
    function pop(s) {
      return s.length ? s.pop() + " " : "";
    }
    function translate(xa, ya, xb, yb, s, q) {
      if (xa !== xb || ya !== yb) {
        var i = s.push("translate(", null, pxComma, null, pxParen);
        q.push({
          i: i - 4,
          x: interpolateNumber(xa, xb)
        }, {
          i: i - 2,
          x: interpolateNumber(ya, yb)
        });
      } else if (xb || yb) {
        s.push("translate(" + xb + pxComma + yb + pxParen);
      }
    }
    function rotate(a, b, s, q) {
      if (a !== b) {
        if (a - b > 180) b += 360;else if (b - a > 180) a += 360; // shortest path
        q.push({
          i: s.push(pop(s) + "rotate(", null, degParen) - 2,
          x: interpolateNumber(a, b)
        });
      } else if (b) {
        s.push(pop(s) + "rotate(" + b + degParen);
      }
    }
    function skewX(a, b, s, q) {
      if (a !== b) {
        q.push({
          i: s.push(pop(s) + "skewX(", null, degParen) - 2,
          x: interpolateNumber(a, b)
        });
      } else if (b) {
        s.push(pop(s) + "skewX(" + b + degParen);
      }
    }
    function scale(xa, ya, xb, yb, s, q) {
      if (xa !== xb || ya !== yb) {
        var i = s.push(pop(s) + "scale(", null, ",", null, ")");
        q.push({
          i: i - 4,
          x: interpolateNumber(xa, xb)
        }, {
          i: i - 2,
          x: interpolateNumber(ya, yb)
        });
      } else if (xb !== 1 || yb !== 1) {
        s.push(pop(s) + "scale(" + xb + "," + yb + ")");
      }
    }
    return function (a, b) {
      var s = [],
        // string constants and placeholders
        q = []; // number interpolators
      a = parse(a), b = parse(b);
      translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);
      rotate(a.rotate, b.rotate, s, q);
      skewX(a.skewX, b.skewX, s, q);
      scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);
      a = b = null; // gc
      return function (t) {
        var i = -1,
          n = q.length,
          o;
        while (++i < n) s[(o = q[i]).i] = o.x(t);
        return s.join("");
      };
    };
  }
  var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)");
  var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")");

  var frame = 0,
    // is an animation frame pending?
    timeout$1 = 0,
    // is a timeout pending?
    interval = 0,
    // are any timers active?
    pokeDelay = 1000,
    // how frequently we check for clock skew
    taskHead,
    taskTail,
    clockLast = 0,
    clockNow = 0,
    clockSkew = 0,
    clock = typeof performance === "object" && performance.now ? performance : Date,
    setFrame = typeof window === "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function (f) {
      setTimeout(f, 17);
    };
  function now() {
    return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);
  }
  function clearNow() {
    clockNow = 0;
  }
  function Timer() {
    this._call = this._time = this._next = null;
  }
  Timer.prototype = timer.prototype = {
    constructor: Timer,
    restart: function (callback, delay, time) {
      if (typeof callback !== "function") throw new TypeError("callback is not a function");
      time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);
      if (!this._next && taskTail !== this) {
        if (taskTail) taskTail._next = this;else taskHead = this;
        taskTail = this;
      }
      this._call = callback;
      this._time = time;
      sleep();
    },
    stop: function () {
      if (this._call) {
        this._call = null;
        this._time = Infinity;
        sleep();
      }
    }
  };
  function timer(callback, delay, time) {
    var t = new Timer();
    t.restart(callback, delay, time);
    return t;
  }
  function timerFlush() {
    now(); // Get the current time, if not already set.
    ++frame; // Pretend we’ve set an alarm, if we haven’t already.
    var t = taskHead,
      e;
    while (t) {
      if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);
      t = t._next;
    }
    --frame;
  }
  function wake() {
    clockNow = (clockLast = clock.now()) + clockSkew;
    frame = timeout$1 = 0;
    try {
      timerFlush();
    } finally {
      frame = 0;
      nap();
      clockNow = 0;
    }
  }
  function poke() {
    var now = clock.now(),
      delay = now - clockLast;
    if (delay > pokeDelay) clockSkew -= delay, clockLast = now;
  }
  function nap() {
    var t0,
      t1 = taskHead,
      t2,
      time = Infinity;
    while (t1) {
      if (t1._call) {
        if (time > t1._time) time = t1._time;
        t0 = t1, t1 = t1._next;
      } else {
        t2 = t1._next, t1._next = null;
        t1 = t0 ? t0._next = t2 : taskHead = t2;
      }
    }
    taskTail = t0;
    sleep(time);
  }
  function sleep(time) {
    if (frame) return; // Soonest alarm already set, or will be.
    if (timeout$1) timeout$1 = clearTimeout(timeout$1);
    var delay = time - clockNow; // Strictly less than if we recomputed clockNow.
    if (delay > 24) {
      if (time < Infinity) timeout$1 = setTimeout(wake, time - clock.now() - clockSkew);
      if (interval) interval = clearInterval(interval);
    } else {
      if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);
      frame = 1, setFrame(wake);
    }
  }

  function timeout (callback, delay, time) {
    var t = new Timer();
    delay = delay == null ? 0 : +delay;
    t.restart(elapsed => {
      t.stop();
      callback(elapsed + delay);
    }, delay, time);
    return t;
  }

  var emptyOn = dispatch("start", "end", "cancel", "interrupt");
  var emptyTween = [];
  var CREATED = 0;
  var SCHEDULED = 1;
  var STARTING = 2;
  var STARTED = 3;
  var RUNNING = 4;
  var ENDING = 5;
  var ENDED = 6;
  function schedule (node, name, id, index, group, timing) {
    var schedules = node.__transition;
    if (!schedules) node.__transition = {};else if (id in schedules) return;
    create(node, id, {
      name: name,
      index: index,
      // For context during callback.
      group: group,
      // For context during callback.
      on: emptyOn,
      tween: emptyTween,
      time: timing.time,
      delay: timing.delay,
      duration: timing.duration,
      ease: timing.ease,
      timer: null,
      state: CREATED
    });
  }
  function init(node, id) {
    var schedule = get(node, id);
    if (schedule.state > CREATED) throw new Error("too late; already scheduled");
    return schedule;
  }
  function set(node, id) {
    var schedule = get(node, id);
    if (schedule.state > STARTED) throw new Error("too late; already running");
    return schedule;
  }
  function get(node, id) {
    var schedule = node.__transition;
    if (!schedule || !(schedule = schedule[id])) throw new Error("transition not found");
    return schedule;
  }
  function create(node, id, self) {
    var schedules = node.__transition,
      tween;

    // Initialize the self timer when the transition is created.
    // Note the actual delay is not known until the first callback!
    schedules[id] = self;
    self.timer = timer(schedule, 0, self.time);
    function schedule(elapsed) {
      self.state = SCHEDULED;
      self.timer.restart(start, self.delay, self.time);

      // If the elapsed delay is less than our first sleep, start immediately.
      if (self.delay <= elapsed) start(elapsed - self.delay);
    }
    function start(elapsed) {
      var i, j, n, o;

      // If the state is not SCHEDULED, then we previously errored on start.
      if (self.state !== SCHEDULED) return stop();
      for (i in schedules) {
        o = schedules[i];
        if (o.name !== self.name) continue;

        // While this element already has a starting transition during this frame,
        // defer starting an interrupting transition until that transition has a
        // chance to tick (and possibly end); see d3/d3-transition#54!
        if (o.state === STARTED) return timeout(start);

        // Interrupt the active transition, if any.
        if (o.state === RUNNING) {
          o.state = ENDED;
          o.timer.stop();
          o.on.call("interrupt", node, node.__data__, o.index, o.group);
          delete schedules[i];
        }

        // Cancel any pre-empted transitions.
        else if (+i < id) {
          o.state = ENDED;
          o.timer.stop();
          o.on.call("cancel", node, node.__data__, o.index, o.group);
          delete schedules[i];
        }
      }

      // Defer the first tick to end of the current frame; see d3/d3#1576.
      // Note the transition may be canceled after start and before the first tick!
      // Note this must be scheduled before the start event; see d3/d3-transition#16!
      // Assuming this is successful, subsequent callbacks go straight to tick.
      timeout(function () {
        if (self.state === STARTED) {
          self.state = RUNNING;
          self.timer.restart(tick, self.delay, self.time);
          tick(elapsed);
        }
      });

      // Dispatch the start event.
      // Note this must be done before the tween are initialized.
      self.state = STARTING;
      self.on.call("start", node, node.__data__, self.index, self.group);
      if (self.state !== STARTING) return; // interrupted
      self.state = STARTED;

      // Initialize the tween, deleting null tween.
      tween = new Array(n = self.tween.length);
      for (i = 0, j = -1; i < n; ++i) {
        if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {
          tween[++j] = o;
        }
      }
      tween.length = j + 1;
    }
    function tick(elapsed) {
      var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),
        i = -1,
        n = tween.length;
      while (++i < n) {
        tween[i].call(node, t);
      }

      // Dispatch the end event.
      if (self.state === ENDING) {
        self.on.call("end", node, node.__data__, self.index, self.group);
        stop();
      }
    }
    function stop() {
      self.state = ENDED;
      self.timer.stop();
      delete schedules[id];
      for (var i in schedules) return; // eslint-disable-line no-unused-vars
      delete node.__transition;
    }
  }

  function interrupt (node, name) {
    var schedules = node.__transition,
      schedule,
      active,
      empty = true,
      i;
    if (!schedules) return;
    name = name == null ? null : name + "";
    for (i in schedules) {
      if ((schedule = schedules[i]).name !== name) {
        empty = false;
        continue;
      }
      active = schedule.state > STARTING && schedule.state < ENDING;
      schedule.state = ENDED;
      schedule.timer.stop();
      schedule.on.call(active ? "interrupt" : "cancel", node, node.__data__, schedule.index, schedule.group);
      delete schedules[i];
    }
    if (empty) delete node.__transition;
  }

  function selection_interrupt (name) {
    return this.each(function () {
      interrupt(this, name);
    });
  }

  function tweenRemove(id, name) {
    var tween0, tween1;
    return function () {
      var schedule = set(this, id),
        tween = schedule.tween;

      // If this node shared tween with the previous node,
      // just assign the updated shared tween and we’re done!
      // Otherwise, copy-on-write.
      if (tween !== tween0) {
        tween1 = tween0 = tween;
        for (var i = 0, n = tween1.length; i < n; ++i) {
          if (tween1[i].name === name) {
            tween1 = tween1.slice();
            tween1.splice(i, 1);
            break;
          }
        }
      }
      schedule.tween = tween1;
    };
  }
  function tweenFunction(id, name, value) {
    var tween0, tween1;
    if (typeof value !== "function") throw new Error();
    return function () {
      var schedule = set(this, id),
        tween = schedule.tween;

      // If this node shared tween with the previous node,
      // just assign the updated shared tween and we’re done!
      // Otherwise, copy-on-write.
      if (tween !== tween0) {
        tween1 = (tween0 = tween).slice();
        for (var t = {
            name: name,
            value: value
          }, i = 0, n = tween1.length; i < n; ++i) {
          if (tween1[i].name === name) {
            tween1[i] = t;
            break;
          }
        }
        if (i === n) tween1.push(t);
      }
      schedule.tween = tween1;
    };
  }
  function transition_tween (name, value) {
    var id = this._id;
    name += "";
    if (arguments.length < 2) {
      var tween = get(this.node(), id).tween;
      for (var i = 0, n = tween.length, t; i < n; ++i) {
        if ((t = tween[i]).name === name) {
          return t.value;
        }
      }
      return null;
    }
    return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));
  }
  function tweenValue(transition, name, value) {
    var id = transition._id;
    transition.each(function () {
      var schedule = set(this, id);
      (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);
    });
    return function (node) {
      return get(node, id).value[name];
    };
  }

  function interpolate (a, b) {
    var c;
    return (typeof b === "number" ? interpolateNumber : b instanceof color ? interpolateRgb : (c = color(b)) ? (b = c, interpolateRgb) : interpolateString)(a, b);
  }

  function attrRemove(name) {
    return function () {
      this.removeAttribute(name);
    };
  }
  function attrRemoveNS(fullname) {
    return function () {
      this.removeAttributeNS(fullname.space, fullname.local);
    };
  }
  function attrConstant(name, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = this.getAttribute(name);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function attrConstantNS(fullname, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = this.getAttributeNS(fullname.space, fullname.local);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function attrFunction(name, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0,
        value1 = value(this),
        string1;
      if (value1 == null) return void this.removeAttribute(name);
      string0 = this.getAttribute(name);
      string1 = value1 + "";
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function attrFunctionNS(fullname, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0,
        value1 = value(this),
        string1;
      if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);
      string0 = this.getAttributeNS(fullname.space, fullname.local);
      string1 = value1 + "";
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function transition_attr (name, value) {
    var fullname = namespace(name),
      i = fullname === "transform" ? interpolateTransformSvg : interpolate;
    return this.attrTween(name, typeof value === "function" ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, "attr." + name, value)) : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname) : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));
  }

  function attrInterpolate(name, i) {
    return function (t) {
      this.setAttribute(name, i.call(this, t));
    };
  }
  function attrInterpolateNS(fullname, i) {
    return function (t) {
      this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));
    };
  }
  function attrTweenNS(fullname, value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function attrTween(name, value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function transition_attrTween (name, value) {
    var key = "attr." + name;
    if (arguments.length < 2) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    var fullname = namespace(name);
    return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));
  }

  function delayFunction(id, value) {
    return function () {
      init(this, id).delay = +value.apply(this, arguments);
    };
  }
  function delayConstant(id, value) {
    return value = +value, function () {
      init(this, id).delay = value;
    };
  }
  function transition_delay (value) {
    var id = this._id;
    return arguments.length ? this.each((typeof value === "function" ? delayFunction : delayConstant)(id, value)) : get(this.node(), id).delay;
  }

  function durationFunction(id, value) {
    return function () {
      set(this, id).duration = +value.apply(this, arguments);
    };
  }
  function durationConstant(id, value) {
    return value = +value, function () {
      set(this, id).duration = value;
    };
  }
  function transition_duration (value) {
    var id = this._id;
    return arguments.length ? this.each((typeof value === "function" ? durationFunction : durationConstant)(id, value)) : get(this.node(), id).duration;
  }

  function easeConstant(id, value) {
    if (typeof value !== "function") throw new Error();
    return function () {
      set(this, id).ease = value;
    };
  }
  function transition_ease (value) {
    var id = this._id;
    return arguments.length ? this.each(easeConstant(id, value)) : get(this.node(), id).ease;
  }

  function easeVarying(id, value) {
    return function () {
      var v = value.apply(this, arguments);
      if (typeof v !== "function") throw new Error();
      set(this, id).ease = v;
    };
  }
  function transition_easeVarying (value) {
    if (typeof value !== "function") throw new Error();
    return this.each(easeVarying(this._id, value));
  }

  function transition_filter (match) {
    if (typeof match !== "function") match = matcher(match);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
        if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
          subgroup.push(node);
        }
      }
    }
    return new Transition(subgroups, this._parents, this._name, this._id);
  }

  function transition_merge (transition) {
    if (transition._id !== this._id) throw new Error();
    for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
      for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
        if (node = group0[i] || group1[i]) {
          merge[i] = node;
        }
      }
    }
    for (; j < m0; ++j) {
      merges[j] = groups0[j];
    }
    return new Transition(merges, this._parents, this._name, this._id);
  }

  function start(name) {
    return (name + "").trim().split(/^|\s+/).every(function (t) {
      var i = t.indexOf(".");
      if (i >= 0) t = t.slice(0, i);
      return !t || t === "start";
    });
  }
  function onFunction(id, name, listener) {
    var on0,
      on1,
      sit = start(name) ? init : set;
    return function () {
      var schedule = sit(this, id),
        on = schedule.on;

      // If this node shared a dispatch with the previous node,
      // just assign the updated shared dispatch and we’re done!
      // Otherwise, copy-on-write.
      if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);
      schedule.on = on1;
    };
  }
  function transition_on (name, listener) {
    var id = this._id;
    return arguments.length < 2 ? get(this.node(), id).on.on(name) : this.each(onFunction(id, name, listener));
  }

  function removeFunction(id) {
    return function () {
      var parent = this.parentNode;
      for (var i in this.__transition) if (+i !== id) return;
      if (parent) parent.removeChild(this);
    };
  }
  function transition_remove () {
    return this.on("end.remove", removeFunction(this._id));
  }

  function transition_select (select) {
    var name = this._name,
      id = this._id;
    if (typeof select !== "function") select = selector(select);
    for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
        if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
          if ("__data__" in node) subnode.__data__ = node.__data__;
          subgroup[i] = subnode;
          schedule(subgroup[i], name, id, i, subgroup, get(node, id));
        }
      }
    }
    return new Transition(subgroups, this._parents, name, id);
  }

  function transition_selectAll (select) {
    var name = this._name,
      id = this._id;
    if (typeof select !== "function") select = selectorAll(select);
    for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {
            if (child = children[k]) {
              schedule(child, name, id, k, children, inherit);
            }
          }
          subgroups.push(children);
          parents.push(node);
        }
      }
    }
    return new Transition(subgroups, parents, name, id);
  }

  var Selection = selection.prototype.constructor;
  function transition_selection () {
    return new Selection(this._groups, this._parents);
  }

  function styleNull(name, interpolate) {
    var string00, string10, interpolate0;
    return function () {
      var string0 = styleValue(this, name),
        string1 = (this.style.removeProperty(name), styleValue(this, name));
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : interpolate0 = interpolate(string00 = string0, string10 = string1);
    };
  }
  function styleRemove(name) {
    return function () {
      this.style.removeProperty(name);
    };
  }
  function styleConstant(name, interpolate, value1) {
    var string00,
      string1 = value1 + "",
      interpolate0;
    return function () {
      var string0 = styleValue(this, name);
      return string0 === string1 ? null : string0 === string00 ? interpolate0 : interpolate0 = interpolate(string00 = string0, value1);
    };
  }
  function styleFunction(name, interpolate, value) {
    var string00, string10, interpolate0;
    return function () {
      var string0 = styleValue(this, name),
        value1 = value(this),
        string1 = value1 + "";
      if (value1 == null) string1 = value1 = (this.style.removeProperty(name), styleValue(this, name));
      return string0 === string1 ? null : string0 === string00 && string1 === string10 ? interpolate0 : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
    };
  }
  function styleMaybeRemove(id, name) {
    var on0,
      on1,
      listener0,
      key = "style." + name,
      event = "end." + key,
      remove;
    return function () {
      var schedule = set(this, id),
        on = schedule.on,
        listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;

      // If this node shared a dispatch with the previous node,
      // just assign the updated shared dispatch and we’re done!
      // Otherwise, copy-on-write.
      if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);
      schedule.on = on1;
    };
  }
  function transition_style (name, value, priority) {
    var i = (name += "") === "transform" ? interpolateTransformCss : interpolate;
    return value == null ? this.styleTween(name, styleNull(name, i)).on("end.style." + name, styleRemove(name)) : typeof value === "function" ? this.styleTween(name, styleFunction(name, i, tweenValue(this, "style." + name, value))).each(styleMaybeRemove(this._id, name)) : this.styleTween(name, styleConstant(name, i, value), priority).on("end.style." + name, null);
  }

  function styleInterpolate(name, i, priority) {
    return function (t) {
      this.style.setProperty(name, i.call(this, t), priority);
    };
  }
  function styleTween(name, value, priority) {
    var t, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);
      return t;
    }
    tween._value = value;
    return tween;
  }
  function transition_styleTween (name, value, priority) {
    var key = "style." + (name += "");
    if (arguments.length < 2) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    return this.tween(key, styleTween(name, value, priority == null ? "" : priority));
  }

  function textConstant(value) {
    return function () {
      this.textContent = value;
    };
  }
  function textFunction(value) {
    return function () {
      var value1 = value(this);
      this.textContent = value1 == null ? "" : value1;
    };
  }
  function transition_text (value) {
    return this.tween("text", typeof value === "function" ? textFunction(tweenValue(this, "text", value)) : textConstant(value == null ? "" : value + ""));
  }

  function textInterpolate(i) {
    return function (t) {
      this.textContent = i.call(this, t);
    };
  }
  function textTween(value) {
    var t0, i0;
    function tween() {
      var i = value.apply(this, arguments);
      if (i !== i0) t0 = (i0 = i) && textInterpolate(i);
      return t0;
    }
    tween._value = value;
    return tween;
  }
  function transition_textTween (value) {
    var key = "text";
    if (arguments.length < 1) return (key = this.tween(key)) && key._value;
    if (value == null) return this.tween(key, null);
    if (typeof value !== "function") throw new Error();
    return this.tween(key, textTween(value));
  }

  function transition_transition () {
    var name = this._name,
      id0 = this._id,
      id1 = newId();
    for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          var inherit = get(node, id0);
          schedule(node, name, id1, i, group, {
            time: inherit.time + inherit.delay + inherit.duration,
            delay: 0,
            duration: inherit.duration,
            ease: inherit.ease
          });
        }
      }
    }
    return new Transition(groups, this._parents, name, id1);
  }

  function transition_end () {
    var on0,
      on1,
      that = this,
      id = that._id,
      size = that.size();
    return new Promise(function (resolve, reject) {
      var cancel = {
          value: reject
        },
        end = {
          value: function () {
            if (--size === 0) resolve();
          }
        };
      that.each(function () {
        var schedule = set(this, id),
          on = schedule.on;

        // If this node shared a dispatch with the previous node,
        // just assign the updated shared dispatch and we’re done!
        // Otherwise, copy-on-write.
        if (on !== on0) {
          on1 = (on0 = on).copy();
          on1._.cancel.push(cancel);
          on1._.interrupt.push(cancel);
          on1._.end.push(end);
        }
        schedule.on = on1;
      });

      // The selection was empty, resolve end immediately
      if (size === 0) resolve();
    });
  }

  var id = 0;
  function Transition(groups, parents, name, id) {
    this._groups = groups;
    this._parents = parents;
    this._name = name;
    this._id = id;
  }
  function newId() {
    return ++id;
  }
  var selection_prototype = selection.prototype;
  Transition.prototype = {
    constructor: Transition,
    select: transition_select,
    selectAll: transition_selectAll,
    selectChild: selection_prototype.selectChild,
    selectChildren: selection_prototype.selectChildren,
    filter: transition_filter,
    merge: transition_merge,
    selection: transition_selection,
    transition: transition_transition,
    call: selection_prototype.call,
    nodes: selection_prototype.nodes,
    node: selection_prototype.node,
    size: selection_prototype.size,
    empty: selection_prototype.empty,
    each: selection_prototype.each,
    on: transition_on,
    attr: transition_attr,
    attrTween: transition_attrTween,
    style: transition_style,
    styleTween: transition_styleTween,
    text: transition_text,
    textTween: transition_textTween,
    remove: transition_remove,
    tween: transition_tween,
    delay: transition_delay,
    duration: transition_duration,
    ease: transition_ease,
    easeVarying: transition_easeVarying,
    end: transition_end,
    [Symbol.iterator]: selection_prototype[Symbol.iterator]
  };

  function cubicInOut(t) {
    return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;
  }

  var defaultTiming = {
    time: null,
    // Set on use.
    delay: 0,
    duration: 250,
    ease: cubicInOut
  };
  function inherit(node, id) {
    var timing;
    while (!(timing = node.__transition) || !(timing = timing[id])) {
      if (!(node = node.parentNode)) {
        throw new Error(`transition ${id} not found`);
      }
    }
    return timing;
  }
  function selection_transition (name) {
    var id, timing;
    if (name instanceof Transition) {
      id = name._id, name = name._name;
    } else {
      id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + "";
    }
    for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
      for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
        if (node = group[i]) {
          schedule(node, name, id, i, group, timing || inherit(node, id));
        }
      }
    }
    return new Transition(groups, this._parents, name, id);
  }

  selection.prototype.interrupt = selection_interrupt;
  selection.prototype.transition = selection_transition;

  function Transform(k, x, y) {
    this.k = k;
    this.x = x;
    this.y = y;
  }
  Transform.prototype = {
    constructor: Transform,
    scale: function (k) {
      return k === 1 ? this : new Transform(this.k * k, this.x, this.y);
    },
    translate: function (x, y) {
      return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);
    },
    apply: function (point) {
      return [point[0] * this.k + this.x, point[1] * this.k + this.y];
    },
    applyX: function (x) {
      return x * this.k + this.x;
    },
    applyY: function (y) {
      return y * this.k + this.y;
    },
    invert: function (location) {
      return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];
    },
    invertX: function (x) {
      return (x - this.x) / this.k;
    },
    invertY: function (y) {
      return (y - this.y) / this.k;
    },
    rescaleX: function (x) {
      return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));
    },
    rescaleY: function (y) {
      return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));
    },
    toString: function () {
      return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")";
    }
  };
  Transform.prototype;

  /*
    HTDMath Static Class - Not intended for instantiation!

    Model parameters:
      k = discount factor (0, Infinity)

    Behavioral variables:
      A = amount
      D = delay
      V = subjective value

    Equations:
      V = A / (1 + kD)
      k = (A - V) / (VD)
  */
  class HTDMath {
    static k = {
      DEFAULT: 0.05,
      MIN: 0,
      MAX: 100,
      STEP: 0.001,
      JUMP: 0.01
    };
    static adk2v(a, d, k) {
      return a / (1 + k * d);
    }
    static adv2k(a, d, v) {
      return (a - v) / (v * d);
    }
  }

  // Internal dependencies

  /* eslint no-restricted-globals: ["off", "self"] */

  self.onmessage = event => {
    const params = {
      k: {
        type: 'real',
        lower: HTDMath.k.MIN,
        upper: HTDMath.k.MAX
      },
      luce: {
        type: 'real',
        lower: 0,
        upper: 100
      }
    };
    const logPost = (state, data) => {
      let lp = 0;

      // Priors
      const kMean = 2;
      const kShape = 3;
      lp += distributionsExports.gamma(state.k, kShape, kShape / kMean);
      // lp += BayesDistributions.unif(state.k, 0, 100);

      const luceMean = 2;
      const luceShape = 3;
      lp += distributionsExports.gamma(state.luce, luceShape, luceShape / luceMean);
      // lp += BayesDistributions.unif(state.luce, 0, 100);

      // Likelihood
      data.forEach(choice => {
        // Values
        const vs = HTDMath.adk2v(choice.as, choice.ds, state.k);
        const vl = HTDMath.adk2v(choice.al, choice.dl, state.k);

        // Choice of sooner or later is sampled from a Bernoulli distribution
        // Luce choice rule is used to compute probability of waiting! (0 = sooner, 1 = later)
        const binval = 1 / (1 + Math.exp(state.luce * (vs - vl)));

        // Actual response
        const response = choice.response === 'first' ? 0 : 1;
        lp += distributionsExports.bern(response, binval);
      });
      return lp;
    };

    // Initializing the sampler
    const sampler = new mcmcExports.AmwgSampler(params, logPost, event.data);
    // Burning some samples to the MCMC gods and sampling 5000 draws
    sampler.burn(1000);
    const samples = sampler.sample(5000);

    // Extract summary stats
    const results = {
      k: median(samples.k),
      luce: median(samples.luce)
    };
    self.postMessage({
      results: results,
      samples: samples
    });
  };

})();
//# sourceMappingURL=htd-fit-worker.js.map

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"htd-fit-worker.js","sources":["../../node_modules/bayes.js/distributions.js","../../node_modules/bayes.js/mcmc.js","../../node_modules/d3-array/src/ascending.js","../../node_modules/d3-array/src/number.js","../../node_modules/d3-array/src/sort.js","../../node_modules/d3-array/src/max.js","../../node_modules/d3-array/src/min.js","../../node_modules/d3-array/src/quickselect.js","../../node_modules/d3-array/src/quantile.js","../../node_modules/d3-array/src/median.js","../../node_modules/d3-dispatch/src/dispatch.js","../../node_modules/d3-selection/src/namespaces.js","../../node_modules/d3-selection/src/namespace.js","../../node_modules/d3-selection/src/creator.js","../../node_modules/d3-selection/src/selector.js","../../node_modules/d3-selection/src/selection/select.js","../../node_modules/d3-selection/src/array.js","../../node_modules/d3-selection/src/selectorAll.js","../../node_modules/d3-selection/src/selection/selectAll.js","../../node_modules/d3-selection/src/matcher.js","../../node_modules/d3-selection/src/selection/selectChild.js","../../node_modules/d3-selection/src/selection/selectChildren.js","../../node_modules/d3-selection/src/selection/filter.js","../../node_modules/d3-selection/src/selection/sparse.js","../../node_modules/d3-selection/src/selection/enter.js","../../node_modules/d3-selection/src/constant.js","../../node_modules/d3-selection/src/selection/data.js","../../node_modules/d3-selection/src/selection/exit.js","../../node_modules/d3-selection/src/selection/join.js","../../node_modules/d3-selection/src/selection/merge.js","../../node_modules/d3-selection/src/selection/order.js","../../node_modules/d3-selection/src/selection/sort.js","../../node_modules/d3-selection/src/selection/call.js","../../node_modules/d3-selection/src/selection/nodes.js","../../node_modules/d3-selection/src/selection/node.js","../../node_modules/d3-selection/src/selection/size.js","../../node_modules/d3-selection/src/selection/empty.js","../../node_modules/d3-selection/src/selection/each.js","../../node_modules/d3-selection/src/selection/attr.js","../../node_modules/d3-selection/src/window.js","../../node_modules/d3-selection/src/selection/style.js","../../node_modules/d3-selection/src/selection/property.js","../../node_modules/d3-selection/src/selection/classed.js","../../node_modules/d3-selection/src/selection/text.js","../../node_modules/d3-selection/src/selection/html.js","../../node_modules/d3-selection/src/selection/raise.js","../../node_modules/d3-selection/src/selection/lower.js","../../node_modules/d3-selection/src/selection/append.js","../../node_modules/d3-selection/src/selection/insert.js","../../node_modules/d3-selection/src/selection/remove.js","../../node_modules/d3-selection/src/selection/clone.js","../../node_modules/d3-selection/src/selection/datum.js","../../node_modules/d3-selection/src/selection/on.js","../../node_modules/d3-selection/src/selection/dispatch.js","../../node_modules/d3-selection/src/selection/iterator.js","../../node_modules/d3-selection/src/selection/index.js","../../node_modules/d3-color/src/define.js","../../node_modules/d3-color/src/color.js","../../node_modules/d3-interpolate/src/constant.js","../../node_modules/d3-interpolate/src/color.js","../../node_modules/d3-interpolate/src/rgb.js","../../node_modules/d3-interpolate/src/number.js","../../node_modules/d3-interpolate/src/string.js","../../node_modules/d3-interpolate/src/transform/decompose.js","../../node_modules/d3-interpolate/src/transform/parse.js","../../node_modules/d3-interpolate/src/transform/index.js","../../node_modules/d3-timer/src/timer.js","../../node_modules/d3-timer/src/timeout.js","../../node_modules/d3-transition/src/transition/schedule.js","../../node_modules/d3-transition/src/interrupt.js","../../node_modules/d3-transition/src/selection/interrupt.js","../../node_modules/d3-transition/src/transition/tween.js","../../node_modules/d3-transition/src/transition/interpolate.js","../../node_modules/d3-transition/src/transition/attr.js","../../node_modules/d3-transition/src/transition/attrTween.js","../../node_modules/d3-transition/src/transition/delay.js","../../node_modules/d3-transition/src/transition/duration.js","../../node_modules/d3-transition/src/transition/ease.js","../../node_modules/d3-transition/src/transition/easeVarying.js","../../node_modules/d3-transition/src/transition/filter.js","../../node_modules/d3-transition/src/transition/merge.js","../../node_modules/d3-transition/src/transition/on.js","../../node_modules/d3-transition/src/transition/remove.js","../../node_modules/d3-transition/src/transition/select.js","../../node_modules/d3-transition/src/transition/selectAll.js","../../node_modules/d3-transition/src/transition/selection.js","../../node_modules/d3-transition/src/transition/style.js","../../node_modules/d3-transition/src/transition/styleTween.js","../../node_modules/d3-transition/src/transition/text.js","../../node_modules/d3-transition/src/transition/textTween.js","../../node_modules/d3-transition/src/transition/transition.js","../../node_modules/d3-transition/src/transition/end.js","../../node_modules/d3-transition/src/transition/index.js","../../node_modules/d3-ease/src/cubic.js","../../node_modules/d3-transition/src/selection/transition.js","../../node_modules/d3-transition/src/selection/index.js","../../node_modules/d3-zoom/src/transform.js","../discountable-math/src/htd-math.js","../discountable-math/src/index.js","src/components/htd-fit-worker.js"],"sourcesContent":["\"use strict\";\n\n\n// A number of log probability density functions (PDF). Naming and parameterization\n// should match R's, except for that all functions reside in an ld object (\n// as in \"log density\"), so to get a normal log density you would write\n// ld.norm(...).\n// Most of the code below is directly taken from the great Jstat project\n// (https://github.com/jstat/) which includes PDF for many common probability\n// distributions. What I have done is only to convert these to log PDFs.\n\n/*\nOriginal work Copyright (c) 2013 jStat\nModified work Copyright (c) 2015 Rasmus Bååth \n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n\n*/\n\n\n// This boiler plate code here is taken from:\n// https://github.com/umdjs/umd/blob/master/templates/returnExports.js\n// It should make shure that module can be imported both in the browser,\n// Node, and by using the Asynchronous Module Definition standard.\n// If this module is loaded in the browser it will created the global\n// object ld .\n(function (root, factory) {\n    if (typeof define === 'function' && define.amd) {\n        // AMD. Register as an anonymous module.\n        define([], factory);\n    } else if (typeof module === 'object' && module.exports) {\n        // Node. Does not work with strict CommonJS, but\n        // only CommonJS-like environments that support module.exports,\n        // like Node.\n        module.exports = factory();\n    } else {\n        // Browser globals (root is window)\n        root.ld = factory();\n  }\n}(this, function() {\n  // Object to hold the functions to be exported.\n  var ld  = {};\n  \n  ////////// Helper functions //////////\n  //////////////////////////////////////\n  \n  var lgamma = function(x) {\n    var j = 0;\n    var cof = [\n      76.18009172947146, -86.50532032941677, 24.01409824083091,\n      -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5\n    ];\n    var ser = 1.000000000190015;\n    var xx, y, tmp;\n    tmp = (y = xx = x) + 5.5;\n    tmp -= (xx + 0.5) * log(tmp);\n    for (; j < 6; j++)\n      ser += cof[j] / ++y;\n    return log(2.5066282746310005 * ser / xx) - tmp;\n  };\n  ld.lgamma = lgamma;\n  \n  var lfactorial = function(n) {\n    return n < 0 ? NaN : lgamma(n + 1);\n  };\n  ld.lfactorial = lfactorial;\n  \n  var lchoose = function(n, k){\n    return lfactorial(n) - lfactorial(k) - lfactorial(n - k);\n  };\n  ld.lchoose = lchoose;\n  \n  var lbeta = function(a, b) {\n    return lgamma(a) + lgamma(b) - lgamma(a + b);\n  };\n  ld.lbeta = lbeta;\n  \n  var log  = Math.log;\n  var exp  = Math.exp;\n  var abs  = Math.abs;\n  var pow  = Math.pow;\n  var sqrt = Math.sqrt;\n  var pi   = Math.PI;\n  \n  ////////// Continous distributions //////////\n  /////////////////////////////////////////////\n  \n  ld.beta = function(x, shape1, shape2) {\n    if (x > 1 || x < 0) {\n        return -Infinity;\n    }\n    if(shape1 === 1 && shape2 === 1) {\n      return 0;\n    } else {\n      return (shape1 - 1) * log(x) + (shape2 - 1) * log(1 - x) - lbeta(shape1, shape2);  \n    }\n  };\n  \n  ld.cauchy = function(x, location, scale) {\n    return log(scale) - log(pow(x - location, 2) + pow(scale, 2))  - log(pi);\n  };\n  \n  ld.norm = function(x, mean, sd) {\n      return -0.5 * log(2 * pi) -log(sd) - pow(x - mean, 2) / (2 * sd * sd);\n  };\n\n  // A bivariate Normal distribution parameterized by arrays of two means and SDs, and \n  // the correlation.\n  ld.bivarnorm = function(x, mean, sd, corr) {\n    var z = pow(x[0] - mean[0], 2) / pow(sd[0], 2) +\n            pow(x[1] - mean[1], 2) / pow(sd[1], 2) - \n            (2 * corr * (x[0] - mean[0]) * (x[1] - mean[1])) / (sd[0] * sd[1]);\n    var normalizing_factor = -( log(2) + log(pi) + log(sd[0]) + log(sd[1]) + \n                                0.5 * log(1 - pow(corr, 2)) ); \n    var bivar_log_dens = normalizing_factor - z / (2 * (1 - pow(corr, 2) ) ); \n    return bivar_log_dens;\n  };\n  \n\n  ld.laplace = function(x, location, scale) {\n    return (-abs(x - location)/scale) - log(2 * scale);\n  };\n  \n  ld.dexp = ld.laplace;\n  \n  ld.gamma = function(x, shape, rate) {\n    var scale = 1 / rate;\n    if (x < 0) {\n      return -Infinity;\n    }\n    if((x === 0 && shape === 1) ) {\n      return -log(scale);\n    } else {\n      return (shape - 1) * log(x) - x / scale - lgamma(shape) - shape * log(scale);\n    }\n  };\n  \n  ld.invgamma = function(x, shape, scale) {\n      if (x <= 0) {\n        return -Infinity;\n      }\n      return -(shape + 1) * log(x) - scale / x - lgamma(shape) + shape * log(scale);\n    };\n  \n  ld.lnorm =  function(x, meanlog, sdlog) {\n    if (x <= 0) {\n      return -Infinity;\n    }\n    return -log(x) - 0.5 * log(2 * pi) - log(sdlog) - \n            pow(log(x) - meanlog, 2) / (2 * sdlog * sdlog);\n  };\n  \n  ld.pareto = function(x, scale, shape) {\n    if (x < scale) {\n      return -Infinity;\n    }\n    return log(shape) + shape * log(scale) - (shape + 1) * log(x);\n  };\n  \n  ld.t  =  function(x, location, scale, df) {\n    df = df > 1e100 ? 1e100 : df;\n    return lgamma((df + 1)/2) - lgamma(df/2) - log(sqrt(pi * df) * scale) +\n           log(pow(1 + (1/df) * pow((x - location)/scale, 2), -(df + 1)/2));\n  };\n  \n  // This is a direct javascript translation of the R code used to evaluate\n  // the log density of a weibull distribution: \n  // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dweibull.c\n  ld.weibull = function(x, shape, scale) {\n    if (x < 0) return -Infinity;\n    if(x === 0 && shape < 1) return Infinity;\n    var tmp1 = pow(x / scale, shape - 1);\n    var tmp2 = tmp1 * (x / scale);\n\t  return -tmp2 + log(shape * tmp1 / scale);\n  };\n  \n  // This is a direct javascript translation of the R code used to evaluate\n  // the log density of a logistic distribution: \n  // https://github.com/wch/r-source/blob/b156e3a711967f58131e23c1b1dc1ea90e2f0c43/src/nmath/dlogis.c\n  ld.logis = function(x, location, scale) {\n    x = abs((x - location) / scale);\n    var e = exp(-x);\n    var f = 1.0 + e;\n    return -(x + log(scale * f * f));    \n  };\n\n  ld.dirichlet = function(x, alpha) {\n    var sum_alpha = 0;\n    var sum_lgamma_alpha = 0;\n    var sum_alpha_sub_1_log_x = 0;\n    var n = alpha.length;\n    for(var i = 0; i < n; i++) {\n      sum_alpha += alpha[i];\n      sum_lgamma_alpha += lgamma(alpha[i]);\n      sum_alpha_sub_1_log_x += (alpha[i] - 1) * log(x[i]);\n    }\n    return lgamma(sum_alpha) - sum_lgamma_alpha + sum_alpha_sub_1_log_x;\n  };\n   \n    \n  ld.exp = function(x, rate) {\n      return x < 0 ? -Infinity : log(rate) -rate * x;\n  };\n  \n  ld.unif = function(x, min, max) {\n      return (x < min || x > max) ? -Infinity : log(1 / (max - min));\n  };\n  \n  ////////// Discrete distributions //////////\n  ////////////////////////////////////////////\n  \n  ld.bern = function(x, prob) {\n      return !(x === 0 || x === 1) ? -Infinity : log(x * prob + (1 - x) * (1 - prob));\n  };\n  \n  ld.cat = function(x, probs) {\n    if(x < 1 || x > probs.length) {\n      return -Infinity;\n    } else {\n      return log( probs[x - 1] );\n    }\n  };\n  \n  ld.binom = function(x, size, prob) {\n    if(x > size || x < 0) {\n      return -Infinity;\n    }\n    if(prob === 0 || prob === 1) {\n      return (size * prob) === x ? 0 : -Infinity;\n    }\n    return lchoose(size, x) + x * log(prob) + (size - x) * log(1 - prob);\n  };\n  \n  var multinom = function(x, probs) {\n    var n = x.length;\n    var size = 0;\n    var tmp_term = 0;\n    for(var i = 0; i < n; i++) {\n      if(probs[i] === 0) {\n        if(x[i] !== 0) {\n          return -Infinity;  \n        }\n      } else {\n        size += x[i];\n        tmp_term += x[i] * log(probs[i]) - lgamma(x[i] + 1);\n      }\n    }\n    return lgamma(size + 1) + tmp_term ;\n  };\n  \n  ld.nbinom = function(x, size, prob) {\n    if(x < 0) {\n      return -Infinity;\n    }\n    return lchoose(x + size - 1, size - 1) + x * log(1 - prob) + size * log(prob);\n  };\n  \n  ld.hyper = function(x, m, n, k) {\n    if(x < 0 || x > k) {\n      return -Infinity;\n    } else {\n    return lchoose(m, x) + lchoose(n, k-x) - lchoose(m+n, k);\n    }\n  };\n  \n  ld.pois = function(x, lambda) {\n      return x < 0 ? -Infinity : log(lambda) * x - lambda - lfactorial(x);\n  };\n  \n  return ld;\n}));","\"use strict\";\n\n// This boiler plate code here is taken from:\n// https://github.com/umdjs/umd/blob/master/templates/returnExports.js\n// It should make shure that module can be imported both in the browser,\n// Node, and by using the Asynchronous Module Definition standard.\n// If this module is loaded in the browser it will created the global\n// object mcmc .\n(function (root, factory) {\n    if (typeof define === 'function' && define.amd) {\n        // AMD. Register as an anonymous module.\n        define([], factory);\n    } else if (typeof module === 'object' && module.exports) {\n        // Node. Does not work with strict CommonJS, but\n        // only CommonJS-like environments that support module.exports,\n        // like Node.\n        module.exports = factory();\n    } else {\n        // Browser globals (root is window)\n        root.mcmc = factory();\n  }\n}(this, function(){\n\n/// The actual module code starts here ///\n//////////////////////////////////////////  \n  \n  ////////// Helper Functions //////////\n  //////////////////////////////////////\n  \n  /** Returns a random real number between min and max */\n  var runif = function(min, max) {\n    return Math.random() * (max - min) + min;\n  };\n  \n  /** Returns a random integer between min and max */\n  var runif_discrete = function(min, max) {\n    return Math.floor(Math.random() * (max - min + 1)) + min;\n  };\n  \n  /** Returns a random real number from a normal distribbution defined\n   *  by mean and sd. \n   *  Adapted from https://github.com/jstat/jstat/blob/master/src/special.js */\n  var rnorm = function(mean, sd) {\n    var u, v, x, y, q;\n    do {\n      u = Math.random();\n      v = 1.7156 * (Math.random() - 0.5);\n      x = u - 0.449871;\n      y = Math.abs(v) + 0.386595;\n      q = x * x + y * (0.19600 * y - 0.25472 * x);\n    } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u));\n    \n    return (v / u) * sd + mean;\n  };\n  \n  \n  /** Returns a deep clone of src, sort of... It only copies a limited\n   * number of types and, for example, function are not copied. \n   * From http://davidwalsh.name/javascript-clone\n   */\n  var deep_clone = function(src) {\n  \tfunction mixin(dest, source, copyFunc) {\n  \t\tvar name, s, i, empty = {};\n  \t\tfor(name in source){\n  \t\t\t// the (!(name in empty) || empty[name] !== s) condition avoids copying properties in \"source\"\n  \t\t\t// inherited from Object.prototype.\t For example, if dest has a custom toString() method,\n  \t\t\t// don't overwrite it with the toString() method that source inherited from Object.prototype\n  \t\t\ts = source[name];\n  \t\t\tif(!(name in dest) || (dest[name] !== s && (!(name in empty) || empty[name] !== s))){\n  \t\t\t\tdest[name] = copyFunc ? copyFunc(s) : s;\n  \t\t\t}\n  \t\t}\n  \t\treturn dest;\n  \t}\n  \tif(!src || typeof src != \"object\" || Object.prototype.toString.call(src) === \"[object Function]\"){\n  \t\t// null, undefined, any non-object, or function\n  \t\treturn src;\t// anything\n  \t}\n  \tif(src.nodeType && \"cloneNode\" in src){\n  \t\t// DOM Node\n  \t\treturn src.cloneNode(true); // Node\n  \t}\n  \tif(src instanceof Date){\n  \t\t// Date\n  \t\treturn new Date(src.getTime());\t// Date\n  \t}\n  \tif(src instanceof RegExp){\n  \t\t// RegExp\n  \t\treturn new RegExp(src);   // RegExp\n  \t}\n  \tvar r, i, l;\n  \tif(src instanceof Array){\n  \t\t// array\n  \t\tr = [];\n  \t\tfor(i = 0, l = src.length; i < l; ++i){\n  \t\t\tif(i in src){\n  \t\t\t\tr.push(deep_clone(src[i]));\n  \t\t\t}\n  \t\t}\n  \t} else {\n  \t\t// generic objects\n  \t\tr = src.constructor ? new src.constructor() : {};\n  \t}\n  \treturn mixin(r, src, deep_clone);\n  };\n  \n  /** Specialized clone function that only clones scalars and nested arrays where\n   * each array either consists of all arrays or all numbers. This function\n   * is meant as a fast way of cloning parameter draws within the mcmc sampling\n   * loop.\n   */\n  var clone_param_draw = function(x) {\n    if(Array.isArray(x)) {\n      if(Array.isArray(x[0])) {\n        // x is an array of arrays so we need to clone it recursively\n        var x_copy = [];\n        for(var i = 0, length = x.length; i < length; i++) {\n          x_copy.push(clone_param_draw(x[i]));\n        } \n        return x_copy;\n      } else { // We'll assume x is a arrays of scalars\n        return x.slice(0);\n      }\n    } else { // We'll assume x is a scalar\n      return x;\n    }\n  };\n  \n  /** Returns true if object is a number.\n   */\n  var is_number = function(object) {\n      return typeof object == \"number\" || (typeof object == \"object\" && object.constructor === Number);\n  };\n  \n  /**\n   * Creates and initializes a (possibly multidimensional/nested) array.\n   * @param dim - An array giving the dimension of the array. For example,\n   *   [5] would yield a 5 element array, and [3,3] would yield a 3 by 3 matrix.\n   * @param init - A value or a function used to fill in the each element in\n   *   the array. If it is a function it should take no arguments, it will be \n   *   evaluated once for each element, and it's return value will be used to\n   *   fill in each element.\n   * @example \n   * // The following would return [[1,1],[1,1],[1,1]]\n   * create_array([2,3], 1)\n   */\n  var create_array = function(dim, init) {\n    var arr = new Array(dim[0]);\n    var i;\n    if(dim.length == 1) { // Fill it up with init\n      if(typeof init === \"function\") {\n        for(i = 0; i < dim[0]; i++) {\n          arr[i] = init();\n        }  \n      } else {\n        for(i = 0; i < dim[0]; i++) {\n          arr[i] = init;\n        } \n      }\n    } else if(dim.length > 1) {\n      for(i = 0; i < dim[0]; i++) {\n        arr[i] = create_array(dim.slice(1), init);\n      }\n    } else {\n      throw \"create_array can't create a dimensionless array\";\n    }\n    return arr;\n  };\n  \n  /**\n   * Return the dimensions of a possibly nested array as an array. For \n   * example, array_dim( [[1, 2], [1, 2]] ) should return [2, 2]\n   * Assumes that all arrays inside another array are of the same length.\n   * @example\n   * // Should return [4, 2, 1]\n   * array_dim(create_array([4, 2, 1], 0))\n   */\n  var array_dim = function(a) {\n    if(Array.isArray(a[0])) {\n      return [a.length].concat(array_dim(a[0]));\n    } else {\n      return [a.length];\n    }\n  };\n  \n  /**\n   * Checks if two arrays are equal in the sense that they contain the same elements\n   * as judged by the \"==\" operator. Returns true or false.\n   * Adapted from http://stackoverflow.com/a/14853974/1001848\n   */ \n  var array_equal = function (a1, a2) {\n      if (a1.length != a2.length) return false;\n      for (var i = 0; i < a1.length; i++) {\n          // Check if we have nested arrays\n          if (Array.isArray(a1[i]) && Array.isArray(a2[i])) {\n              // recurse into the nested arrays\n              if (!array_equal(a1[i], a2[i])) return false;       \n          }           \n          else if (a1[i] != a2[i]) { \n              // Warning - two different object instances will never be equal: {x:20} != {x:20}\n              return false;   \n          }           \n      }       \n      return true;\n  };\n  \n  /**\n   * Traverses a possibly nested array a and applies fun to all \"leaf nodes\", \n   * that is, values that are not arrays. Returns an array of the same size as\n   * a.\n   */\n  var nested_array_apply = function(a, fun) {\n    if(Array.isArray(a)) {\n      var result = new Array(a.length);\n      for(var i = 0; i < a.length; i++) {\n        result[i] = nested_array_apply(a[i], fun);\n      }\n      return result;\n    } else {\n      return fun(a);\n    }\n  };\n  \n  /** Randomizing the array element order in-place. Using Durstenfeld\n   * shuffle algorithm. Adapted from here: \n   * http://stackoverflow.com/a/12646864/1001848\n   */\n  function shuffle_array(array) {\n      for (var i = array.length - 1; i > 0; i--) {\n          var j = Math.floor(Math.random() * (i + 1));\n          var temp = array[i];\n          array[i] = array[j];\n          array[j] = temp;\n      }\n      return array;\n  }\n  \n  /**\n   * Does the same thing as nested_array_apply, that is, traverses a possibly\n   * nested array a and applies fun to all \"leaf nodes\" and returns an array \n   * of the same size as a. The difference is that nested_array_random_apply\n   * branches randomly.\n   */\n  var nested_array_random_apply = function(a, fun) {\n    if(Array.isArray(a)) {\n      var len = a.length;\n      var i;\n      var array_is = [];\n      for(i = 0; i < len; i++) {\n        array_is[i] = i;\n      }\n      shuffle_array(array_is);\n      var result = [];\n      \n      for(i = 0; i < len; i++) {\n        var array_i = array_is[i];\n        result[array_i] = nested_array_apply(a[array_i], fun);\n      }\n      return result;\n    } else {\n      return fun(a);\n    }\n  };\n  \n  /**\n   * Allows a pretty way of setting default options where the defults can be\n   * overridden by an options object.\n   *  @param option_name - the name of the option as a string\n   *  @param my_options - an option object that could have option_name \n   *    as a member.\n   * @param defaul_value - defult value that is returned if option_name \n   *   is not defined in my_options.\n   * @example\n   * var my_options = {pi: 3.14159}\n   * var pi = get_option(\"pi\", my_options, 3.14)\n   */\n  // Pretty way of setting default options where the defaults can be overridden\n  // by an options object. For example:\n  // var pi = get_option(\"pi\", my_options, 3.14)\n  var get_option = function(option_name, options, defaul_value) {\n    options = options || {};\n    return options.hasOwnProperty(option_name) && \n           options[option_name] !== undefined  && \n           options[option_name] !== null ? options[option_name] : defaul_value;\n  };\n  \n  /** Version of get_option where the option should be a one or multi-dimensional\n   * array and where the default can be overridden either by a scalar or by an array.\n   * If it's a scalar the that scalar is used to initialize an array with \n   * dim dimensions.\n   * \n   */\n  var get_multidim_option = function(option_name, options, dim, defaul_value) {\n    var value = get_option(option_name, options, defaul_value);\n     if(! Array.isArray(value)) {\n       value = create_array(dim, value);\n     } \n     if(! array_equal( array_dim(value), dim)) {\n       throw \"The option \" + option_name + \" is of dimension [\" + \n             array_dim(value) + \"] but should be [\" + dim + \"].\";\n    }\n     return value;\n  };\n  \n  ////////// Functions for handling parameter objects //////////\n  //////////////////////////////////////////////////////////////\n  \n  /**\n   * Returns a fixed (same every time) number that could be used to initialize\n   * a parameter of a certain type, possibly with lower and upper bounds.\n   * The possile types are \"real\", \"int\", and \"binary\".\n   */\n  var param_init_fixed = function(type, lower, upper) {\n    if(lower > upper) {\n      throw \"Can not initialize parameter where lower bound > upper bound\";\n    }\n    if(type === \"real\") {\n      if(lower === -Infinity && upper === Infinity) {\n        return 0.5;\n      } else if(lower === -Infinity) {\n        return upper - 0.5;\n      } else if(upper === Infinity) {\n        return lower + 0.5;\n      } else if(lower <= upper) {\n        return (lower + upper) / 2;\n      }\n    } else if(type === \"int\") {\n      if(lower === -Infinity && upper === Infinity) {\n        return 1;\n      } else if(lower === -Infinity) {\n        return upper - 1;\n      } else if(upper === Infinity) {\n        return lower + 1;\n      } else if(lower <= upper){\n        return Math.round((lower + upper) / 2);\n      }\n    } else if(type === \"binary\") {\n      return 1;\n    }\n    throw \"Could not initialize parameter of type \" + type + \"[\" + lower + \", \" + upper + \"]\";\n  };\n  \n  /**\n   * Completes params_to_complete, an object containing parameter descriptions, \n   * and initializes non-initialized parameters. This modified version of\n   * params_to_complete is returned as a deep copy and not modified in place.\n   * Initialization is done by supplying a param_init function with signature\n   * function(type, lower, upper) that should return a single number \n   * (like param_init_fixed, for example).\n   * @example\n   * var params = { \"mu\": {\"type\": \"real\"} }\n   * params = complete_params(params);\n   * // params should now be:\n   * //  {\"mu\": { \"type\": \"real\", \"dim\": [1], \"upper\": Infinity,\n   * //           \"lower\": -Infinity, \"init\": 0.5 }}\n   */ \n  var complete_params  = function(params_to_complete, param_init) {\n    var params = deep_clone(params_to_complete);\n    for (var param_name in params) { if (!params.hasOwnProperty(param_name)) continue;\n      var param = params[param_name];\n      if( !param.hasOwnProperty(\"type\")) {\n        param.type = \"real\";\n      }\n      if(!param.hasOwnProperty(\"dim\")) {\n        param.dim = [1];\n      }\n      if(is_number(param.dim)) {\n        param.dim = [param.dim];\n      }\n      if(param.type == \"binary\") {\n        param.upper = 1;\n        param.lower = 0;\n      }\n      if(!param.hasOwnProperty(\"upper\")) {\n        param.upper = Infinity;\n      }\n      if(!param.hasOwnProperty(\"lower\")) {\n        param.lower = -Infinity;\n      }\n      \n      if(param.hasOwnProperty(\"init\")) {\n        // If this is just a number or a nested array we leave it alone, but if...\n        if(array_equal(param.dim, [1]) && typeof param.init === \"function\") {\n          // param.init is a function, use that to initialize the parameter.\n          param.init = param.init();\n        } else if(!array_equal(param.dim, [1]) && !Array.isArray(param.init)) {\n        // We have a multidimensional parameter where the param.init exist but\n        // is not an array. Then assume it is a number or a function and use\n        // it to initialize the parameter.\n        param.init = create_array(param.dim, param.init);\n        }\n      } else { // We use the default initialization function.\n        if(array_equal(param.dim, [1])) {\n          param.init = param_init(param.type, param.lower, param.upper);\n        } else {\n          param.init = create_array(param.dim, function() {\n            return param_init(param.type, param.lower, param.upper);\n          });\n        }\n      }\n    }\n    return params;\n  };\n  \n  \n  ////////// Stepper Functions ///////////\n  ////////////////////////////////////////\n  \n  \n  /**\n   * @interface\n   * A Stepper is an object responsible for pushing around one\n   * or more parameter values in a state according to the distribution\n   * defined by the log posterior. This defines the Stepper \"interface\",\n   * where \"interface\" means that Stepper defines a class that is never\n   * meant to be instantiated, but just to be subclassed by specialized\n   * stepper functions.\n   * @interface\n   * @param params - An object with parameter definitions, for example:\n   *   {\"mu\": { \"type\": \"real\", \"dim\": [1], \"upper\": Infinity, \n   *   \"lower\": -Infinity, \"init\": 0.5 }}\n   *   The parameter definitions are expected to be \"complete\", that is,\n   *   specifying all relevant attributes such as dim, lower and upper.\n   * @param state - an object containing the state of all parameters in params\n   *   (and possibly more). The parameter names are given as keys and the states\n   *   as scalars or, possibly nested, arrays. For example:\n   *   {mu: 10, sigma: 5, beta: [1, 2.5]}\n   * @param log_post - A function *taking no parameters* that returns the\n   *   log density that depends on the state. That is, the value of log_post\n   *   should change if the the values in state are changed.\n  \n   */\n  var Stepper = function(params, state, log_post) {\n    this.params = params;\n    this.state = state;\n    this.log_post = log_post;\n  };\n  \n  /**\n   * Takes a step in the parameter space. Should return the new state,\n   * but is mainly called for it's side effect of making a change in the\n   * state object.\n   */\n  Stepper.prototype.step = function() {\n    throw \"Every Stepper need to implement step()\";\n  };\n  \n  /**\n   * If implemented, makes the stepper adapt while stepping.\n   */ \n  Stepper.prototype.start_adaptation = function() {\n    // Optional, some steppers might not be adaptive. */ \n  };\n  \n  /**\n   * If implemented, makes the stepper cease adapting while stepping.\n   */ \n  Stepper.prototype.stop_adaptation = function() {\n    // Optional, some steppers might not be adaptive. */ \n  };\n  \n  /**\n   * Returns an object containg info regarding the stepper.\n   */ \n  Stepper.prototype.info = function() {\n    // Returns an object with info about the state of the stepper.\n    return {};\n  };\n  \n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements the metropolis step in\n   * the Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008).\n   * @param params - An object with a single parameter definition.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n   * @param generate_proposal - a function returning a proposal (as a number)\n   * with signature function(param_state, log_scale) where param_state is a\n   * number and log_scale defines the scale of the proposal somehow.\n  */\n  var OnedimMetropolisStepper = function(params, state, log_post, options, generate_proposal) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  != 1) {\n      throw \"OnedimMetropolisStepper can only handle one parameter.\";\n    }\n    this.param_name = param_names[0];\n    var param = this.params[this.param_name];\n    if(!array_equal(param.dim, [1])) {\n      throw \"OnedimMetropolisStepper can only handle one one-dimensional parameter.\";\n    }\n    this.lower = param.lower;\n    this.upper = param.upper;\n    \n    this.prop_log_scale     = get_option(\"prop_log_scale\", options, 0);\n    this.batch_size         = get_option(\"batch_size\", options, 50);\n    this.max_adaptation     = get_option(\"max_adaptation\", options, 0.33);\n    this.initial_adaptation = get_option(\"initial_adaptation\", options, 1.0);\n    this.target_accept_rate = get_option(\"target_accept_rate\", options, 0.44);\n    this.is_adapting        = get_option(\"is_adapting\", options, true);\n    \n    this.generate_proposal = generate_proposal;\n    \n    this.acceptance_count = 0;\n    this.batch_count = 0;\n    this.iterations_since_adaption = 0;  \n  };\n  \n  OnedimMetropolisStepper.prototype = Object.create(Stepper.prototype); \n  OnedimMetropolisStepper.prototype.constructor = OnedimMetropolisStepper;\n  \n  OnedimMetropolisStepper.prototype.step = function() {\n      var param_state = this.state[this.param_name];\n      var param_proposal = this.generate_proposal(param_state, this.prop_log_scale);\n      if(param_proposal < this.lower || param_proposal > this.upper) {\n        // Outside of limits of the parameter, reject the proposal \n        // and stay at the current state.\n      } else { // make a Metropolis step\n        var curr_log_dens = this.log_post();\n        this.state[this.param_name] = param_proposal;\n        var prop_log_dens = this.log_post();\n        var accept_prob = Math.exp(prop_log_dens - curr_log_dens);\n        if(accept_prob > Math.random()) {\n          // We do nothing as the state of param has already been changed to the proposal\n          if(this.is_adapting) this.acceptance_count++ ;\n        } else {\n          // revert state back to the old state of param\n          this.state[this.param_name] = param_state;\n        }\n      }\n      if(this.is_adapting) {\n        this.iterations_since_adaption ++;\n        if(this.iterations_since_adaption >= this.batch_size) { // then adapt\n          this.batch_count ++;\n          var log_sd_adjustment = \n            Math.min(this.max_adaptation, \n                     this.initial_adaptation / Math.sqrt(this.batch_count));\n          if(this.acceptance_count / this.batch_size > this.target_accept_rate) {\n            this.prop_log_scale += log_sd_adjustment;\n          } else {\n            this.prop_log_scale -= log_sd_adjustment;\n          }\n          this.acceptance_count = 0;\n          this.iterations_since_adaption = 0;\n        }\n      }\n      return this.state[this.param_name];\n  };\n  \n  OnedimMetropolisStepper.prototype.start_adaptation = function() {\n    this.is_adapting = true;\n  };\n  \n  OnedimMetropolisStepper.prototype.stop_adaptation = function() {\n    this.is_adapting = false;\n  };\n  \n  OnedimMetropolisStepper.prototype.info = function() {\n    return {\n      prop_log_scale: this.prop_log_scale,\n      is_adapting: this.is_adapting,\n      acceptance_count: this.acceptance_count,\n      iterations_since_adaption: this.iterations_since_adaption,\n      batch_count: this.batch_count\n    };\n  };\n  \n  \n  /**\n   * Function returning a Normal proposal.\n   */\n  var normal_proposal = function(param_state, prop_log_scale) {\n    return rnorm(param_state , Math.exp(prop_log_scale));\n  };\n  \n  /**\n   * @class\n   * @augments {OnedimMetropolisStepper}\n   * A \"subclass\" of OnedimMetropolisStepper making continous Normal proposals.\n   */\n  var RealMetropolisStepper = function(params, state, log_post, options) {\n    OnedimMetropolisStepper.call(this, params, state, log_post, options, normal_proposal);\n  };\n  \n  RealMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype); \n  RealMetropolisStepper.prototype.constructor = RealMetropolisStepper;\n  \n  /**\n   * Function returning a discretized Normal proposal.\n   */\n  var discrete_normal_proposal = function(param_state, prop_log_scale) {\n    return Math.round(rnorm(param_state , Math.exp(prop_log_scale)));\n  };\n  \n    /**\n   * @class\n   * @augments {OnedimMetropolisStepper}\n   * A \"subclass\" of OnedimMetropolisStepper making discretized Normal proposals.\n   */\n  var IntMetropolisStepper = function(params, state, log_post, options) {\n    OnedimMetropolisStepper.call(this, params, state, log_post, options, discrete_normal_proposal);\n  };\n  \n  IntMetropolisStepper.prototype = Object.create(OnedimMetropolisStepper.prototype); \n  IntMetropolisStepper.prototype.constructor = IntMetropolisStepper;\n  \n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements the metropolis step in\n   * the Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008) for possibly multidimensional arrays. That\n   * is, instead of just taking a step for a one-dimensional parameter like \n   * OnedimMetropolisStepper, this Stepper is responsible for taking steps \n   * for a multidimensional array. It's still pretty dumb and just takes\n   * one-dimensional steps for each parameter component, though.\n   * @param params - An object with a single parameter definition for a \n   *   multidimensional parameter.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n   * @param SubStepper - a constructor for the type of one dimensional Stepper to apply on\n   *   all the components of the multidimensional parameter.\n  */\n  var MultidimComponentMetropolisStepper = function(params, state, log_post, options, SubStepper) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  != 1) {\n      throw \"MultidimComponentMetropolisStepper can't handle more than one parameter.\";\n    }\n    this.param_name = param_names[0];\n    var param = this.params[this.param_name];\n    this.lower = param.lower;\n    this.upper = param.upper;\n    this.dim = param.dim;\n  \n    this.prop_log_scale     = get_multidim_option(\"prop_log_scale\", options, this.dim, 0);\n    this.batch_size         = get_multidim_option(\"batch_size\", options, this.dim, 50);\n    this.max_adaptation     = get_multidim_option(\"max_adaptation\", options, this.dim, 0.33);\n    this.initial_adaptation = get_multidim_option(\"initial_adaptation\", options, this.dim, 1.0);\n    this.target_accept_rate = get_multidim_option(\"target_accept_rate\", options, this.dim, 0.44);\n    this.is_adapting        = get_multidim_option(\"is_adapting\", options, this.dim, true);\n    \n    // This hack below is a recursive function that creates an array of \n    // one dimensional steppers according to dim.\n    var create_substeppers = \n      function(dim, substate, log_post, prop_log_scale, batch_size, max_adaptation, initial_adaptation, target_accept_rate, is_adapting) {\n      var substeppers = [];\n      if(dim.length === 1) {\n        for(var i = 0; i < dim[0]; i++) {\n          var suboptions = {prop_log_scale: prop_log_scale[i], batch_size: batch_size[i],\n            max_adaptation: max_adaptation[i], initial_adaptation: initial_adaptation[i],\n            target_accept_rate: target_accept_rate[i], is_adapting: is_adapting[i]};\n            var subparam = {};\n            subparam[i] = deep_clone(param);\n            subparam[i].dim = [1]; // As this should now be a one-dim parameter\n            delete subparam[i].init; // As it sould not be needed\n          substeppers[i] = new SubStepper(subparam, substate, log_post, suboptions);\n        }\n      } else {\n        for(var i = 0; i < dim[0]; i++) {\n          substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post, prop_log_scale[i], \n            batch_size[i], max_adaptation[i], initial_adaptation[i], target_accept_rate[i], is_adapting[i]);\n        }\n      }\n      return substeppers;\n    };\n    \n    this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post,\n      this.prop_log_scale, this.batch_size, this.max_adaptation, this.initial_adaptation,\n      this.target_accept_rate, this.is_adapting);\n    \n  };\n  \n  MultidimComponentMetropolisStepper.prototype = Object.create(Stepper.prototype); \n  MultidimComponentMetropolisStepper.prototype.constructor = MultidimComponentMetropolisStepper;\n  \n  MultidimComponentMetropolisStepper.prototype.step = function() {\n    // Go through the substeppers in a random order and call step() on them.\n    return nested_array_random_apply(this.substeppers, function(substepper) {return substepper.step(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.start_adaptation = function() {\n    nested_array_apply(this.substeppers, function(substepper) {substepper.start_adaptation(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.stop_adaptation = function() {\n    nested_array_apply(this.substeppers, function(substepper) {substepper.stop_adaptation(); });\n  };\n  \n  MultidimComponentMetropolisStepper.prototype.info = function() {\n    return nested_array_apply(this.substeppers, function(substepper) {\n      return substepper.info(); \n    });\n  };\n  \n  /**\n   * @class\n   * @augments {MultidimComponentMetropolisStepper}\n   * A \"subclass\" of MultidimComponentMetropolisStepper making continous Normal proposals.\n   */\n  var MultiRealComponentMetropolisStepper = function(params, state, log_post, options) {\n    MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, RealMetropolisStepper);\n  };\n  \n  MultiRealComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype); \n  MultiRealComponentMetropolisStepper.prototype.constructor = MultiRealComponentMetropolisStepper;\n\n  /**\n   * @class\n   * @augments {MultidimComponentMetropolisStepper}\n   * A \"subclass\" of MultidimComponentMetropolisStepper making discretized Normal proposals.\n   */    \n  var MultiIntComponentMetropolisStepper = function(params, state, log_post, options) {\n    MultidimComponentMetropolisStepper.call(this, params, state, log_post, options, IntMetropolisStepper);\n  };\n  \n  MultiIntComponentMetropolisStepper.prototype = Object.create(MultidimComponentMetropolisStepper.prototype); \n  MultiIntComponentMetropolisStepper.prototype.constructor = MultiIntComponentMetropolisStepper;\n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * Constructor for an object that implements a step for a binary parameter.\n   * This is done by evaluating the log posterior for both states of the\n   * parameter and then selecting a state randomly with probability relative \n   * to the posterior of each state.\n   * @param params - An object with a single parameter definition.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var BinaryStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    var param_names = Object.keys(this.params);\n    if(param_names.length  == 1) {\n      this.param_name = param_names[0];\n    } else {\n      throw \"BinaryStepper can't handle more than one parameter.\";\n    }\n  };\n  \n  BinaryStepper.prototype = Object.create(Stepper.prototype); \n  BinaryStepper.prototype.constructor = BinaryStepper;\n  \n  BinaryStepper.prototype.step = function() {\n    this.state[this.param_name] = 0;\n    var zero_log_dens = this.log_post();\n    this.state[this.param_name] = 1;\n    var one_log_dens = this.log_post();\n    var max_log_dens = Math.max(zero_log_dens, one_log_dens);\n    zero_log_dens -= max_log_dens;\n    one_log_dens -= max_log_dens;\n    var zero_prob = Math.exp(zero_log_dens - Math.log( Math.exp(zero_log_dens) + Math.exp(one_log_dens) ) );\n    if(Math.random() < zero_prob) {\n      this.state[this.param_name] = 0;\n      return 0;\n    } // else keep the param at 1 .\n    return 1;\n  };\n  \n    /**\n   * @class\n   * @implements {Stepper}\n   * Just like MultidimComponentMetropolisStepper this Stepper takes a steps for\n   * a multidimensional parameter by updating each component in turn. The difference\n   * is that this stepper works on binary parameters.\n   * @param params - An object with a single parameter definition for a \n   *   multidimensional parameter.\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var BinaryComponentStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    \n    var param_names = Object.keys(this.params);\n    if(param_names.length  == 1) {\n      this.param_name = param_names[0];\n      var param = this.params[this.param_name];\n      this.dim = param.dim;\n    } else {\n      throw \"BinaryComponentStepper can't handle more than one parameter.\";\n    }\n    \n    var create_substeppers = \n      function(dim, substate, log_post) {\n      var substeppers = [];\n      var i;\n      if(dim.length === 1) {\n        for(i = 0; i < dim[0]; i++) {\n          var subparams = {};\n          subparams[i] = param;\n          substeppers[i] = new BinaryStepper(subparams, substate, log_post);\n        }\n      } else {\n        for(i = 0; i < dim[0]; i++) {\n          substeppers[i] = create_substeppers(dim.slice(1), substate[i], log_post);\n        }\n      }\n      return substeppers;\n    };\n    \n    this.substeppers = create_substeppers(this.dim, this.state[this.param_name], this.log_post);\n  };\n  \n  BinaryComponentStepper.prototype = Object.create(Stepper.prototype); \n  BinaryComponentStepper.prototype.constructor = BinaryComponentStepper;\n  \n  BinaryComponentStepper.prototype.step = function() {\n    // Go through the substeppers in a random order and call step() on them.\n    return nested_array_random_apply(this.substeppers, function(substepper) {return substepper.step(); });\n  };\n  \n  /**\n   * @class\n   * @implements {Stepper}\n   * This stepper can be responsible for taking a step for one or more parameters.\n   * For real and int parameters it takes Metropolis within Gibbs steps, and for \n   * binary parameters it does evaluates the posterior for both paramter values and\n   * randomly changes to a certain value proportionally to that value's posterior\n   * (this is also done for each parameter, so also a * within Gibbs approach).\n   * This stepper is also adaptive and can be efficient when the number of parameters\n   * are not too high and the correlations between parameters are low.\n   * @param params - An object with a one or more parameter definitions\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var AmwgStepper = function(params, state, log_post, options) {\n    Stepper.call(this, params, state, log_post);\n    this.param_names = Object.keys(this.params);\n    this.substeppers = [];\n    for(var i = 0; i < this.param_names.length; i++) {\n      var param = params[this.param_names[i]];\n      var SelectStepper;\n      switch (param.type) {\n        case \"real\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = RealMetropolisStepper;\n          } else {\n            SelectStepper = MultiRealComponentMetropolisStepper;\n          }\n          break;\n        case \"int\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = IntMetropolisStepper;\n          } else {\n            SelectStepper = MultiIntComponentMetropolisStepper;\n          }\n          break;\n        case \"binary\":\n          if(array_equal(param.dim, [1])) {\n            SelectStepper = BinaryStepper;\n          } else {\n            SelectStepper = BinaryComponentStepper;\n          }\n          break;\n        default:\n          throw \"AmwgStepper can't handle parameter \" + this.param_names[i]  +\" with type \" + param.type; \n      }\n      var param_object_wrap = {};\n      param_object_wrap[this.param_names[i]] = param;\n      options = options || {};\n      var param_options = options.params && options.params[this.param_names[i]] || {};\n      param_options.prop_log_scale     = param_options.prop_log_scale     || options.prop_log_scale; \n      param_options.batch_size         = param_options.batch_size         || options.batch_size; \n      param_options.max_adaptation     = param_options.max_adaptation     || options.max_adaptation;\n      param_options.initial_adaptation = param_options.initial_adaptation || options.initial_adaptation;\n      param_options.target_accept_rate = param_options.target_accept_rate || options.target_accept_rate; \n      param_options.is_adapting        = param_options.is_adapting        || options.is_adapting; \n      this.substeppers[i] = new SelectStepper(param_object_wrap, state, log_post, param_options);\n    }\n  };\n  \n  AmwgStepper.prototype = Object.create(Stepper.prototype); \n  AmwgStepper.prototype.constructor = AmwgStepper;\n  \n  AmwgStepper.prototype.step = function() {\n    shuffle_array(this.substeppers);\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].step();\n    }\n    return this.state;\n  };\n  \n  AmwgStepper.prototype.start_adaptation = function() {\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].start_adaptation();\n    }\n  };\n  \n  AmwgStepper.prototype.stop_adaptation = function() {\n    for(var i = 0; i < this.substeppers.length; i++) {\n      this.substeppers[i].stop_adaptation();\n    } \n  };\n  \n  AmwgStepper.prototype.info = function() {\n    var info = {};\n    for(var i = 0; i < this.substeppers.length; i++) {\n      info[this.param_names[i]] = this.substeppers[i].info();\n    }\n    return info;\n  };\n  \n  \n  \n  /////////// Sampler Functions //////////\n  ////////////////////////////////////////\n  \n  \n   /**\n   * @interface\n   * While you could fit a model by pasting together Steppers, a\n  // Sampler is here is a convenience class where an instance of Sampler\n  // sets up the Steppers, checks the parameter definition,\n  // and manages the sampling. This here defines the Sampler \"interface\".\n   * @interface\n   * @param params - An object with parameter definitions, for example:\n   *   {\"mu\": {\"type\": \"real\"}, \"sigma\": {\"type\": \"real\", \"lower\" = 0}}\n   *   The parameter definitions doesn't have to be \"complete\" and properties\n   *   left out (like lower and upper) will be filled in by defaults.\n   * @param log_post - A function with signature function(state, data). Here\n   *   state will be an object representing the state with each parameter as a \n   *   key and the parameter values as numbers or arrays. For example:\n   *   {\"mu\": 3, \"sigma\": 1.5}. The data argument will be the same object as \n   *   the data argument given below.\n   * @param data - an object that will be passed on to the log_post function\n   *   when sampling.\n   * @param options - an object with options to the sampler.\n   */\n  var Sampler = function(params, log_post, data, options) {\n    this.params = params;\n    this.data = data;\n    this.param_names = Object.keys(this.params);\n    \n    // Setting default options if not passed through the options object\n    this.param_init_fun   = get_option(\"param_init_fun\", options, param_init_fixed);\n    var thinning_interval = get_option(\"thin\", options, 1);\n    var params_to_monitor = get_option(\"monitor\", options, null);\n    this.thin(thinning_interval);\n    this.monitor(params_to_monitor);\n    this.options = options;\n    // Completing the params and initializing the state.\n    this.params = complete_params(this.params, this.param_init_fun);\n    var state = {};\n    for(var i = 0; i < this.param_names.length; i++ ) {\n      state[this.param_names[i]] = this.params[this.param_names[i]].init;\n    }\n    this.log_post = function() { \n      return log_post(state, data);\n    };\n    // Running the log_post function once in case it further modifies the state\n    // for example adding derived quantities.\n    this.log_post();\n    this.state = state;\n    this.steppers = this.create_stepper_ensamble(this.params, this.state, this.log_post, this.options);\n  };\n  \n  /** Should return a vector of steppers that when called \n   * should take a step in the parameter space.\n   */\n  Sampler.prototype.create_stepper_ensamble = function(state, log_post){\n    throw \"Every Sampler needs to implement create_stepper_ensamble()\";\n  };\n  \n  /** Returns an object with info about the state of the Sampler.\n   */ \n  Sampler.prototype.info = function() {\n    return {state: this.state, thin: this.thin, monitor: this.monitor,\n            steppers: this.steppers};\n  };\n  \n  /** Takes a step in the parameter space. Returns the new space\n   * but also modifies the state in place.\n   */ \n  Sampler.prototype.step = function() {\n    shuffle_array(this.steppers);\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].step();\n    }\n    if(Object.keys(this.state).length > Object.keys(this.params).length) {\n      // The state contains devived quantities (not only parameters) and we\n      // need to run the log_post once more in order to set the derived quantities\n      // for the final parameter state\n      this.log_post();\n    }\n    return this.state;\n  };\n  \n  /**\n   * Takes n_iterations steps in the parameter space and returns them\n   * as an object of arrays with one array per parameter. For example:\n   * {mu: [1, -1, 2, 3, ...], sigma: [1, 2, 2, 1, ...]}.\n   * If thin is > 1 then n_iterations / thin samples are returned.\n   */ \n  Sampler.prototype.sample = function(n_iterations) {\n      // Initializing curr_sample where the sample is going to be saved\n      // as an object containing one array per parameter to be monitored.\n      var i, j, monitored_params;\n      if(this.monitored_params === null) {\n        monitored_params = Object.keys(this.state);\n      } else {\n        monitored_params = this.monitored_params;\n      }\n      \n      var curr_sample = {};\n      for(j = 0; j < monitored_params.length; j++) {\n        curr_sample[monitored_params[j]] = [];\n      }\n      \n      for(i = 0; i < n_iterations; i++) {\n        if(i % this.thinning_interval === 0) {\n          for(j = 0; j < monitored_params.length; j++) {\n            var param = monitored_params[j];\n            curr_sample[param].push( clone_param_draw(this.state[param]) );\n          }\n        }\n        this.step();\n      }\n      return curr_sample;\n  };\n  \n  /**\n   * Takes n_iteration steps in parameter space but returns nothing.\n   */ \n  Sampler.prototype.burn = function(n_iterations) {\n    for(var i = 0; i < n_iterations; i++) {\n      this.step();\n    }\n  };\n  \n  /**\n   * Sets what parameters should be monitored and returned when calling\n   * sample.\n   */ \n  Sampler.prototype.monitor = function(params_to_monitor) {\n      this.monitored_params = params_to_monitor;\n  };\n  \n  /**\n   * Sets the thinning. For example thin == 10 means that every 10th posterior\n   * draw will be kept.\n   */ \n  Sampler.prototype.thin = function(thinning_interval) {\n    this.thinning_interval = thinning_interval;\n  };\n  \n  /**\n   * Sets adaptation on, if applicable, in all steppers.\n   */ \n  Sampler.prototype.start_adaptation = function() {\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].start_adaptation();\n    }\n  };\n  \n    /**\n   * Sets adaptation off, if applicable, in all steppers.\n   */ \n  Sampler.prototype.stop_adaptation = function() {\n    for(var i = 0; i < this.steppers.length; i++) {\n      this.steppers[i].stop_adaptation();\n    }\n  };\n  \n   /**\n   * @class\n   * @implements {Sampler}\n   * This sampler uses the AmwgStepper as the stepper function which implements the \n   * Adaptive Metropolis-Within-Gibbs algorithm in \"Examples of Adaptive MCMC\"\n   * by Roberts and Rosenthal (2008). An adition is that it handles int parameters\n   * by making discrete Normal proposals and binary parameters by taking on a new \n   * value proportional to the posterior of the two possible states of the\n   * parameter. This sampler can be efficient when the number of parameters\n   * are not too high and the correlations between parameters are low.\n   * @param params - An object with a one or more parameter definitions\n   * @param state - an object containing the state of all parameters.\n   * @param log_post - A function that returns the log density that depends on the state. \n   * @param options - an object with options to the stepper.\n  */\n  var AmwgSampler = function(params, log_post, data, options) {\n    Sampler.call(this, params, log_post, data, options);\n  };\n  \n  AmwgSampler.prototype = Object.create(Sampler.prototype); \n  AmwgSampler.prototype.constructor = AmwgSampler;\n  \n  AmwgSampler.prototype.create_stepper_ensamble = function(params, state, log_post, options){\n    return [ new AmwgStepper(params, state, log_post, options) ];\n  };\n  \n  \n  // Returning the functions that should be publicly exposed by this module\n  return {\n    runif: runif,\n    runif_discrete: runif_discrete,\n    rnorm: rnorm,\n    param_init_fixed: param_init_fixed, \n    complete_params: complete_params, \n    RealMetropolisStepper: RealMetropolisStepper, \n    IntMetropolisStepper: IntMetropolisStepper, \n    MultiRealComponentMetropolisStepper: MultiRealComponentMetropolisStepper, \n    MultiIntComponentMetropolisStepper: MultiIntComponentMetropolisStepper, \n    BinaryStepper: BinaryStepper, \n    BinaryComponentStepper: BinaryComponentStepper, \n    AmwgStepper: AmwgStepper, \n    AmwgSampler: AmwgSampler\n  };\n}));\n","export default function ascending(a, b) {\n  return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","export default function number(x) {\n  return x === null ? NaN : +x;\n}\n\nexport function* numbers(values, valueof) {\n  if (valueof === undefined) {\n    for (let value of values) {\n      if (value != null && (value = +value) >= value) {\n        yield value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n        yield value;\n      }\n    }\n  }\n}\n","import ascending from \"./ascending.js\";\nimport permute from \"./permute.js\";\n\nexport default function sort(values, ...F) {\n  if (typeof values[Symbol.iterator] !== \"function\") throw new TypeError(\"values is not iterable\");\n  values = Array.from(values);\n  let [f] = F;\n  if ((f && f.length !== 2) || F.length > 1) {\n    const index = Uint32Array.from(values, (d, i) => i);\n    if (F.length > 1) {\n      F = F.map(f => values.map(f));\n      index.sort((i, j) => {\n        for (const f of F) {\n          const c = ascendingDefined(f[i], f[j]);\n          if (c) return c;\n        }\n      });\n    } else {\n      f = values.map(f);\n      index.sort((i, j) => ascendingDefined(f[i], f[j]));\n    }\n    return permute(values, index);\n  }\n  return values.sort(compareDefined(f));\n}\n\nexport function compareDefined(compare = ascending) {\n  if (compare === ascending) return ascendingDefined;\n  if (typeof compare !== \"function\") throw new TypeError(\"compare is not a function\");\n  return (a, b) => {\n    const x = compare(a, b);\n    if (x || x === 0) return x;\n    return (compare(b, b) === 0) - (compare(a, a) === 0);\n  };\n}\n\nexport function ascendingDefined(a, b) {\n  return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);\n}\n","export default function max(values, valueof) {\n  let max;\n  if (valueof === undefined) {\n    for (const value of values) {\n      if (value != null\n          && (max < value || (max === undefined && value >= value))) {\n        max = value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null\n          && (max < value || (max === undefined && value >= value))) {\n        max = value;\n      }\n    }\n  }\n  return max;\n}\n","export default function min(values, valueof) {\n  let min;\n  if (valueof === undefined) {\n    for (const value of values) {\n      if (value != null\n          && (min > value || (min === undefined && value >= value))) {\n        min = value;\n      }\n    }\n  } else {\n    let index = -1;\n    for (let value of values) {\n      if ((value = valueof(value, ++index, values)) != null\n          && (min > value || (min === undefined && value >= value))) {\n        min = value;\n      }\n    }\n  }\n  return min;\n}\n","import {ascendingDefined, compareDefined} from \"./sort.js\";\n\n// Based on https://github.com/mourner/quickselect\n// ISC license, Copyright 2018 Vladimir Agafonkin.\nexport default function quickselect(array, k, left = 0, right = Infinity, compare) {\n  k = Math.floor(k);\n  left = Math.floor(Math.max(0, left));\n  right = Math.floor(Math.min(array.length - 1, right));\n\n  if (!(left <= k && k <= right)) return array;\n\n  compare = compare === undefined ? ascendingDefined : compareDefined(compare);\n\n  while (right > left) {\n    if (right - left > 600) {\n      const n = right - left + 1;\n      const m = k - left + 1;\n      const z = Math.log(n);\n      const s = 0.5 * Math.exp(2 * z / 3);\n      const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n      const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n      const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n      quickselect(array, k, newLeft, newRight, compare);\n    }\n\n    const t = array[k];\n    let i = left;\n    let j = right;\n\n    swap(array, left, k);\n    if (compare(array[right], t) > 0) swap(array, left, right);\n\n    while (i < j) {\n      swap(array, i, j), ++i, --j;\n      while (compare(array[i], t) < 0) ++i;\n      while (compare(array[j], t) > 0) --j;\n    }\n\n    if (compare(array[left], t) === 0) swap(array, left, j);\n    else ++j, swap(array, j, right);\n\n    if (j <= k) left = j + 1;\n    if (k <= j) right = j - 1;\n  }\n\n  return array;\n}\n\nfunction swap(array, i, j) {\n  const t = array[i];\n  array[i] = array[j];\n  array[j] = t;\n}\n","import max from \"./max.js\";\nimport maxIndex from \"./maxIndex.js\";\nimport min from \"./min.js\";\nimport minIndex from \"./minIndex.js\";\nimport quickselect from \"./quickselect.js\";\nimport number, {numbers} from \"./number.js\";\nimport {ascendingDefined} from \"./sort.js\";\nimport greatest from \"./greatest.js\";\n\nexport default function quantile(values, p, valueof) {\n  values = Float64Array.from(numbers(values, valueof));\n  if (!(n = values.length) || isNaN(p = +p)) return;\n  if (p <= 0 || n < 2) return min(values);\n  if (p >= 1) return max(values);\n  var n,\n      i = (n - 1) * p,\n      i0 = Math.floor(i),\n      value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),\n      value1 = min(values.subarray(i0 + 1));\n  return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileSorted(values, p, valueof = number) {\n  if (!(n = values.length) || isNaN(p = +p)) return;\n  if (p <= 0 || n < 2) return +valueof(values[0], 0, values);\n  if (p >= 1) return +valueof(values[n - 1], n - 1, values);\n  var n,\n      i = (n - 1) * p,\n      i0 = Math.floor(i),\n      value0 = +valueof(values[i0], i0, values),\n      value1 = +valueof(values[i0 + 1], i0 + 1, values);\n  return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileIndex(values, p, valueof = number) {\n  if (isNaN(p = +p)) return;\n  numbers = Float64Array.from(values, (_, i) => number(valueof(values[i], i, values)));\n  if (p <= 0) return minIndex(numbers);\n  if (p >= 1) return maxIndex(numbers);\n  var numbers,\n      index = Uint32Array.from(values, (_, i) => i),\n      j = numbers.length - 1,\n      i = Math.floor(j * p);\n  quickselect(index, i, 0, j, (i, j) => ascendingDefined(numbers[i], numbers[j]));\n  i = greatest(index.subarray(0, i + 1), (i) => numbers[i]);\n  return i >= 0 ? i : -1;\n}\n","import quantile, {quantileIndex} from \"./quantile.js\";\n\nexport default function median(values, valueof) {\n  return quantile(values, 0.5, valueof);\n}\n\nexport function medianIndex(values, valueof) {\n  return quantileIndex(values, 0.5, valueof);\n}\n","var noop = {value: () => {}};\n\nfunction dispatch() {\n  for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n    if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n    _[t] = [];\n  }\n  return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n  this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n    return {type: t, name: name};\n  });\n}\n\nDispatch.prototype = dispatch.prototype = {\n  constructor: Dispatch,\n  on: function(typename, callback) {\n    var _ = this._,\n        T = parseTypenames(typename + \"\", _),\n        t,\n        i = -1,\n        n = T.length;\n\n    // If no callback was specified, return the callback of the given type and name.\n    if (arguments.length < 2) {\n      while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n      return;\n    }\n\n    // If a type was specified, set the callback for the given type and name.\n    // Otherwise, if a null callback was specified, remove callbacks of the given name.\n    if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n    while (++i < n) {\n      if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n      else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n    }\n\n    return this;\n  },\n  copy: function() {\n    var copy = {}, _ = this._;\n    for (var t in _) copy[t] = _[t].slice();\n    return new Dispatch(copy);\n  },\n  call: function(type, that) {\n    if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  },\n  apply: function(type, that, args) {\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  }\n};\n\nfunction get(type, name) {\n  for (var i = 0, n = type.length, c; i < n; ++i) {\n    if ((c = type[i]).name === name) {\n      return c.value;\n    }\n  }\n}\n\nfunction set(type, name, callback) {\n  for (var i = 0, n = type.length; i < n; ++i) {\n    if (type[i].name === name) {\n      type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n      break;\n    }\n  }\n  if (callback != null) type.push({name: name, value: callback});\n  return type;\n}\n\nexport default dispatch;\n","export var xhtml = \"http://www.w3.org/1999/xhtml\";\n\nexport default {\n  svg: \"http://www.w3.org/2000/svg\",\n  xhtml: xhtml,\n  xlink: \"http://www.w3.org/1999/xlink\",\n  xml: \"http://www.w3.org/XML/1998/namespace\",\n  xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\n","import namespaces from \"./namespaces.js\";\n\nexport default function(name) {\n  var prefix = name += \"\", i = prefix.indexOf(\":\");\n  if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n  return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name; // eslint-disable-line no-prototype-builtins\n}\n","import namespace from \"./namespace.js\";\nimport {xhtml} from \"./namespaces.js\";\n\nfunction creatorInherit(name) {\n  return function() {\n    var document = this.ownerDocument,\n        uri = this.namespaceURI;\n    return uri === xhtml && document.documentElement.namespaceURI === xhtml\n        ? document.createElement(name)\n        : document.createElementNS(uri, name);\n  };\n}\n\nfunction creatorFixed(fullname) {\n  return function() {\n    return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n  };\n}\n\nexport default function(name) {\n  var fullname = namespace(name);\n  return (fullname.local\n      ? creatorFixed\n      : creatorInherit)(fullname);\n}\n","function none() {}\n\nexport default function(selector) {\n  return selector == null ? none : function() {\n    return this.querySelector(selector);\n  };\n}\n","import {Selection} from \"./index.js\";\nimport selector from \"../selector.js\";\n\nexport default function(select) {\n  if (typeof select !== \"function\") select = selector(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n}\n","// Given something array like (or null), returns something that is strictly an\n// array. This is used to ensure that array-like objects passed to d3.selectAll\n// or selection.selectAll are converted into proper arrays when creating a\n// selection; we don’t ever want to create a selection backed by a live\n// HTMLCollection or NodeList. However, note that selection.selectAll will use a\n// static NodeList as a group, since it safely derived from querySelectorAll.\nexport default function array(x) {\n  return x == null ? [] : Array.isArray(x) ? x : Array.from(x);\n}\n","function empty() {\n  return [];\n}\n\nexport default function(selector) {\n  return selector == null ? empty : function() {\n    return this.querySelectorAll(selector);\n  };\n}\n","import {Selection} from \"./index.js\";\nimport array from \"../array.js\";\nimport selectorAll from \"../selectorAll.js\";\n\nfunction arrayAll(select) {\n  return function() {\n    return array(select.apply(this, arguments));\n  };\n}\n\nexport default function(select) {\n  if (typeof select === \"function\") select = arrayAll(select);\n  else select = selectorAll(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        subgroups.push(select.call(node, node.__data__, i, group));\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, parents);\n}\n","export default function(selector) {\n  return function() {\n    return this.matches(selector);\n  };\n}\n\nexport function childMatcher(selector) {\n  return function(node) {\n    return node.matches(selector);\n  };\n}\n\n","import {childMatcher} from \"../matcher.js\";\n\nvar find = Array.prototype.find;\n\nfunction childFind(match) {\n  return function() {\n    return find.call(this.children, match);\n  };\n}\n\nfunction childFirst() {\n  return this.firstElementChild;\n}\n\nexport default function(match) {\n  return this.select(match == null ? childFirst\n      : childFind(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","import {childMatcher} from \"../matcher.js\";\n\nvar filter = Array.prototype.filter;\n\nfunction children() {\n  return Array.from(this.children);\n}\n\nfunction childrenFilter(match) {\n  return function() {\n    return filter.call(this.children, match);\n  };\n}\n\nexport default function(match) {\n  return this.selectAll(match == null ? children\n      : childrenFilter(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","import {Selection} from \"./index.js\";\nimport matcher from \"../matcher.js\";\n\nexport default function(match) {\n  if (typeof match !== \"function\") match = matcher(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n}\n","export default function(update) {\n  return new Array(update.length);\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n  return new Selection(this._enter || this._groups.map(sparse), this._parents);\n}\n\nexport function EnterNode(parent, datum) {\n  this.ownerDocument = parent.ownerDocument;\n  this.namespaceURI = parent.namespaceURI;\n  this._next = null;\n  this._parent = parent;\n  this.__data__ = datum;\n}\n\nEnterNode.prototype = {\n  constructor: EnterNode,\n  appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n  insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n  querySelector: function(selector) { return this._parent.querySelector(selector); },\n  querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n};\n","export default function(x) {\n  return function() {\n    return x;\n  };\n}\n","import {Selection} from \"./index.js\";\nimport {EnterNode} from \"./enter.js\";\nimport constant from \"../constant.js\";\n\nfunction bindIndex(parent, group, enter, update, exit, data) {\n  var i = 0,\n      node,\n      groupLength = group.length,\n      dataLength = data.length;\n\n  // Put any non-null nodes that fit into update.\n  // Put any null nodes into enter.\n  // Put any remaining data into enter.\n  for (; i < dataLength; ++i) {\n    if (node = group[i]) {\n      node.__data__ = data[i];\n      update[i] = node;\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Put any non-null nodes that don’t fit into exit.\n  for (; i < groupLength; ++i) {\n    if (node = group[i]) {\n      exit[i] = node;\n    }\n  }\n}\n\nfunction bindKey(parent, group, enter, update, exit, data, key) {\n  var i,\n      node,\n      nodeByKeyValue = new Map,\n      groupLength = group.length,\n      dataLength = data.length,\n      keyValues = new Array(groupLength),\n      keyValue;\n\n  // Compute the key for each node.\n  // If multiple nodes have the same key, the duplicates are added to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if (node = group[i]) {\n      keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + \"\";\n      if (nodeByKeyValue.has(keyValue)) {\n        exit[i] = node;\n      } else {\n        nodeByKeyValue.set(keyValue, node);\n      }\n    }\n  }\n\n  // Compute the key for each datum.\n  // If there a node associated with this key, join and add it to update.\n  // If there is not (or the key is a duplicate), add it to enter.\n  for (i = 0; i < dataLength; ++i) {\n    keyValue = key.call(parent, data[i], i, data) + \"\";\n    if (node = nodeByKeyValue.get(keyValue)) {\n      update[i] = node;\n      node.__data__ = data[i];\n      nodeByKeyValue.delete(keyValue);\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Add any remaining nodes that were not bound to data to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if ((node = group[i]) && (nodeByKeyValue.get(keyValues[i]) === node)) {\n      exit[i] = node;\n    }\n  }\n}\n\nfunction datum(node) {\n  return node.__data__;\n}\n\nexport default function(value, key) {\n  if (!arguments.length) return Array.from(this, datum);\n\n  var bind = key ? bindKey : bindIndex,\n      parents = this._parents,\n      groups = this._groups;\n\n  if (typeof value !== \"function\") value = constant(value);\n\n  for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n    var parent = parents[j],\n        group = groups[j],\n        groupLength = group.length,\n        data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),\n        dataLength = data.length,\n        enterGroup = enter[j] = new Array(dataLength),\n        updateGroup = update[j] = new Array(dataLength),\n        exitGroup = exit[j] = new Array(groupLength);\n\n    bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n    // Now connect the enter nodes to their following update node, such that\n    // appendChild can insert the materialized enter node before this node,\n    // rather than at the end of the parent node.\n    for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n      if (previous = enterGroup[i0]) {\n        if (i0 >= i1) i1 = i0 + 1;\n        while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n        previous._next = next || null;\n      }\n    }\n  }\n\n  update = new Selection(update, parents);\n  update._enter = enter;\n  update._exit = exit;\n  return update;\n}\n\n// Given some data, this returns an array-like view of it: an object that\n// exposes a length property and allows numeric indexing. Note that unlike\n// selectAll, this isn’t worried about “live” collections because the resulting\n// array will only be used briefly while data is being bound. (It is possible to\n// cause the data to change while iterating by using a key function, but please\n// don’t; we’d rather avoid a gratuitous copy.)\nfunction arraylike(data) {\n  return typeof data === \"object\" && \"length\" in data\n    ? data // Array, TypedArray, NodeList, array-like\n    : Array.from(data); // Map, Set, iterable, string, or anything else\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n  return new Selection(this._exit || this._groups.map(sparse), this._parents);\n}\n","export default function(onenter, onupdate, onexit) {\n  var enter = this.enter(), update = this, exit = this.exit();\n  if (typeof onenter === \"function\") {\n    enter = onenter(enter);\n    if (enter) enter = enter.selection();\n  } else {\n    enter = enter.append(onenter + \"\");\n  }\n  if (onupdate != null) {\n    update = onupdate(update);\n    if (update) update = update.selection();\n  }\n  if (onexit == null) exit.remove(); else onexit(exit);\n  return enter && update ? enter.merge(update).order() : update;\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(context) {\n  var selection = context.selection ? context.selection() : context;\n\n  for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Selection(merges, this._parents);\n}\n","export default function() {\n\n  for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n    for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n      if (node = group[i]) {\n        if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);\n        next = node;\n      }\n    }\n  }\n\n  return this;\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(compare) {\n  if (!compare) compare = ascending;\n\n  function compareNode(a, b) {\n    return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n  }\n\n  for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        sortgroup[i] = node;\n      }\n    }\n    sortgroup.sort(compareNode);\n  }\n\n  return new Selection(sortgroups, this._parents).order();\n}\n\nfunction ascending(a, b) {\n  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","export default function() {\n  var callback = arguments[0];\n  arguments[0] = this;\n  callback.apply(null, arguments);\n  return this;\n}\n","export default function() {\n  return Array.from(this);\n}\n","export default function() {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n      var node = group[i];\n      if (node) return node;\n    }\n  }\n\n  return null;\n}\n","export default function() {\n  let size = 0;\n  for (const node of this) ++size; // eslint-disable-line no-unused-vars\n  return size;\n}\n","export default function() {\n  return !this.node();\n}\n","export default function(callback) {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n      if (node = group[i]) callback.call(node, node.__data__, i, group);\n    }\n  }\n\n  return this;\n}\n","import namespace from \"../namespace.js\";\n\nfunction attrRemove(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant(name, value) {\n  return function() {\n    this.setAttribute(name, value);\n  };\n}\n\nfunction attrConstantNS(fullname, value) {\n  return function() {\n    this.setAttributeNS(fullname.space, fullname.local, value);\n  };\n}\n\nfunction attrFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttribute(name);\n    else this.setAttribute(name, v);\n  };\n}\n\nfunction attrFunctionNS(fullname, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n    else this.setAttributeNS(fullname.space, fullname.local, v);\n  };\n}\n\nexport default function(name, value) {\n  var fullname = namespace(name);\n\n  if (arguments.length < 2) {\n    var node = this.node();\n    return fullname.local\n        ? node.getAttributeNS(fullname.space, fullname.local)\n        : node.getAttribute(fullname);\n  }\n\n  return this.each((value == null\n      ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS : attrFunction)\n      : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n}\n","export default function(node) {\n  return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n      || (node.document && node) // node is a Window\n      || node.defaultView; // node is a Document\n}\n","import defaultView from \"../window.js\";\n\nfunction styleRemove(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant(name, value, priority) {\n  return function() {\n    this.style.setProperty(name, value, priority);\n  };\n}\n\nfunction styleFunction(name, value, priority) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.style.removeProperty(name);\n    else this.style.setProperty(name, v, priority);\n  };\n}\n\nexport default function(name, value, priority) {\n  return arguments.length > 1\n      ? this.each((value == null\n            ? styleRemove : typeof value === \"function\"\n            ? styleFunction\n            : styleConstant)(name, value, priority == null ? \"\" : priority))\n      : styleValue(this.node(), name);\n}\n\nexport function styleValue(node, name) {\n  return node.style.getPropertyValue(name)\n      || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);\n}\n","function propertyRemove(name) {\n  return function() {\n    delete this[name];\n  };\n}\n\nfunction propertyConstant(name, value) {\n  return function() {\n    this[name] = value;\n  };\n}\n\nfunction propertyFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) delete this[name];\n    else this[name] = v;\n  };\n}\n\nexport default function(name, value) {\n  return arguments.length > 1\n      ? this.each((value == null\n          ? propertyRemove : typeof value === \"function\"\n          ? propertyFunction\n          : propertyConstant)(name, value))\n      : this.node()[name];\n}\n","function classArray(string) {\n  return string.trim().split(/^|\\s+/);\n}\n\nfunction classList(node) {\n  return node.classList || new ClassList(node);\n}\n\nfunction ClassList(node) {\n  this._node = node;\n  this._names = classArray(node.getAttribute(\"class\") || \"\");\n}\n\nClassList.prototype = {\n  add: function(name) {\n    var i = this._names.indexOf(name);\n    if (i < 0) {\n      this._names.push(name);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  remove: function(name) {\n    var i = this._names.indexOf(name);\n    if (i >= 0) {\n      this._names.splice(i, 1);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  contains: function(name) {\n    return this._names.indexOf(name) >= 0;\n  }\n};\n\nfunction classedAdd(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.add(names[i]);\n}\n\nfunction classedRemove(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.remove(names[i]);\n}\n\nfunction classedTrue(names) {\n  return function() {\n    classedAdd(this, names);\n  };\n}\n\nfunction classedFalse(names) {\n  return function() {\n    classedRemove(this, names);\n  };\n}\n\nfunction classedFunction(names, value) {\n  return function() {\n    (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n  };\n}\n\nexport default function(name, value) {\n  var names = classArray(name + \"\");\n\n  if (arguments.length < 2) {\n    var list = classList(this.node()), i = -1, n = names.length;\n    while (++i < n) if (!list.contains(names[i])) return false;\n    return true;\n  }\n\n  return this.each((typeof value === \"function\"\n      ? classedFunction : value\n      ? classedTrue\n      : classedFalse)(names, value));\n}\n","function textRemove() {\n  this.textContent = \"\";\n}\n\nfunction textConstant(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.textContent = v == null ? \"\" : v;\n  };\n}\n\nexport default function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? textRemove : (typeof value === \"function\"\n          ? textFunction\n          : textConstant)(value))\n      : this.node().textContent;\n}\n","function htmlRemove() {\n  this.innerHTML = \"\";\n}\n\nfunction htmlConstant(value) {\n  return function() {\n    this.innerHTML = value;\n  };\n}\n\nfunction htmlFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.innerHTML = v == null ? \"\" : v;\n  };\n}\n\nexport default function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? htmlRemove : (typeof value === \"function\"\n          ? htmlFunction\n          : htmlConstant)(value))\n      : this.node().innerHTML;\n}\n","function raise() {\n  if (this.nextSibling) this.parentNode.appendChild(this);\n}\n\nexport default function() {\n  return this.each(raise);\n}\n","function lower() {\n  if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n}\n\nexport default function() {\n  return this.each(lower);\n}\n","import creator from \"../creator.js\";\n\nexport default function(name) {\n  var create = typeof name === \"function\" ? name : creator(name);\n  return this.select(function() {\n    return this.appendChild(create.apply(this, arguments));\n  });\n}\n","import creator from \"../creator.js\";\nimport selector from \"../selector.js\";\n\nfunction constantNull() {\n  return null;\n}\n\nexport default function(name, before) {\n  var create = typeof name === \"function\" ? name : creator(name),\n      select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n  return this.select(function() {\n    return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n  });\n}\n","function remove() {\n  var parent = this.parentNode;\n  if (parent) parent.removeChild(this);\n}\n\nexport default function() {\n  return this.each(remove);\n}\n","function selection_cloneShallow() {\n  var clone = this.cloneNode(false), parent = this.parentNode;\n  return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nfunction selection_cloneDeep() {\n  var clone = this.cloneNode(true), parent = this.parentNode;\n  return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nexport default function(deep) {\n  return this.select(deep ? selection_cloneDeep : selection_cloneShallow);\n}\n","export default function(value) {\n  return arguments.length\n      ? this.property(\"__data__\", value)\n      : this.node().__data__;\n}\n","function contextListener(listener) {\n  return function(event) {\n    listener.call(this, event, this.__data__);\n  };\n}\n\nfunction parseTypenames(typenames) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    return {type: t, name: name};\n  });\n}\n\nfunction onRemove(typename) {\n  return function() {\n    var on = this.__on;\n    if (!on) return;\n    for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n      if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.options);\n      } else {\n        on[++i] = o;\n      }\n    }\n    if (++i) on.length = i;\n    else delete this.__on;\n  };\n}\n\nfunction onAdd(typename, value, options) {\n  return function() {\n    var on = this.__on, o, listener = contextListener(value);\n    if (on) for (var j = 0, m = on.length; j < m; ++j) {\n      if ((o = on[j]).type === typename.type && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.options);\n        this.addEventListener(o.type, o.listener = listener, o.options = options);\n        o.value = value;\n        return;\n      }\n    }\n    this.addEventListener(typename.type, listener, options);\n    o = {type: typename.type, name: typename.name, value: value, listener: listener, options: options};\n    if (!on) this.__on = [o];\n    else on.push(o);\n  };\n}\n\nexport default function(typename, value, options) {\n  var typenames = parseTypenames(typename + \"\"), i, n = typenames.length, t;\n\n  if (arguments.length < 2) {\n    var on = this.node().__on;\n    if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n      for (i = 0, o = on[j]; i < n; ++i) {\n        if ((t = typenames[i]).type === o.type && t.name === o.name) {\n          return o.value;\n        }\n      }\n    }\n    return;\n  }\n\n  on = value ? onAdd : onRemove;\n  for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));\n  return this;\n}\n","import defaultView from \"../window.js\";\n\nfunction dispatchEvent(node, type, params) {\n  var window = defaultView(node),\n      event = window.CustomEvent;\n\n  if (typeof event === \"function\") {\n    event = new event(type, params);\n  } else {\n    event = window.document.createEvent(\"Event\");\n    if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n    else event.initEvent(type, false, false);\n  }\n\n  node.dispatchEvent(event);\n}\n\nfunction dispatchConstant(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params);\n  };\n}\n\nfunction dispatchFunction(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params.apply(this, arguments));\n  };\n}\n\nexport default function(type, params) {\n  return this.each((typeof params === \"function\"\n      ? dispatchFunction\n      : dispatchConstant)(type, params));\n}\n","export default function*() {\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n      if (node = group[i]) yield node;\n    }\n  }\n}\n","import selection_select from \"./select.js\";\nimport selection_selectAll from \"./selectAll.js\";\nimport selection_selectChild from \"./selectChild.js\";\nimport selection_selectChildren from \"./selectChildren.js\";\nimport selection_filter from \"./filter.js\";\nimport selection_data from \"./data.js\";\nimport selection_enter from \"./enter.js\";\nimport selection_exit from \"./exit.js\";\nimport selection_join from \"./join.js\";\nimport selection_merge from \"./merge.js\";\nimport selection_order from \"./order.js\";\nimport selection_sort from \"./sort.js\";\nimport selection_call from \"./call.js\";\nimport selection_nodes from \"./nodes.js\";\nimport selection_node from \"./node.js\";\nimport selection_size from \"./size.js\";\nimport selection_empty from \"./empty.js\";\nimport selection_each from \"./each.js\";\nimport selection_attr from \"./attr.js\";\nimport selection_style from \"./style.js\";\nimport selection_property from \"./property.js\";\nimport selection_classed from \"./classed.js\";\nimport selection_text from \"./text.js\";\nimport selection_html from \"./html.js\";\nimport selection_raise from \"./raise.js\";\nimport selection_lower from \"./lower.js\";\nimport selection_append from \"./append.js\";\nimport selection_insert from \"./insert.js\";\nimport selection_remove from \"./remove.js\";\nimport selection_clone from \"./clone.js\";\nimport selection_datum from \"./datum.js\";\nimport selection_on from \"./on.js\";\nimport selection_dispatch from \"./dispatch.js\";\nimport selection_iterator from \"./iterator.js\";\n\nexport var root = [null];\n\nexport function Selection(groups, parents) {\n  this._groups = groups;\n  this._parents = parents;\n}\n\nfunction selection() {\n  return new Selection([[document.documentElement]], root);\n}\n\nfunction selection_selection() {\n  return this;\n}\n\nSelection.prototype = selection.prototype = {\n  constructor: Selection,\n  select: selection_select,\n  selectAll: selection_selectAll,\n  selectChild: selection_selectChild,\n  selectChildren: selection_selectChildren,\n  filter: selection_filter,\n  data: selection_data,\n  enter: selection_enter,\n  exit: selection_exit,\n  join: selection_join,\n  merge: selection_merge,\n  selection: selection_selection,\n  order: selection_order,\n  sort: selection_sort,\n  call: selection_call,\n  nodes: selection_nodes,\n  node: selection_node,\n  size: selection_size,\n  empty: selection_empty,\n  each: selection_each,\n  attr: selection_attr,\n  style: selection_style,\n  property: selection_property,\n  classed: selection_classed,\n  text: selection_text,\n  html: selection_html,\n  raise: selection_raise,\n  lower: selection_lower,\n  append: selection_append,\n  insert: selection_insert,\n  remove: selection_remove,\n  clone: selection_clone,\n  datum: selection_datum,\n  on: selection_on,\n  dispatch: selection_dispatch,\n  [Symbol.iterator]: selection_iterator\n};\n\nexport default selection;\n","export default function(constructor, factory, prototype) {\n  constructor.prototype = factory.prototype = prototype;\n  prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n  var prototype = Object.create(parent.prototype);\n  for (var key in definition) prototype[key] = definition[key];\n  return prototype;\n}\n","import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n    reN = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n    reP = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n    reHex = /^#([0-9a-f]{3,8})$/,\n    reRgbInteger = new RegExp(`^rgb\\\\(${reI},${reI},${reI}\\\\)$`),\n    reRgbPercent = new RegExp(`^rgb\\\\(${reP},${reP},${reP}\\\\)$`),\n    reRgbaInteger = new RegExp(`^rgba\\\\(${reI},${reI},${reI},${reN}\\\\)$`),\n    reRgbaPercent = new RegExp(`^rgba\\\\(${reP},${reP},${reP},${reN}\\\\)$`),\n    reHslPercent = new RegExp(`^hsl\\\\(${reN},${reP},${reP}\\\\)$`),\n    reHslaPercent = new RegExp(`^hsla\\\\(${reN},${reP},${reP},${reN}\\\\)$`);\n\nvar named = {\n  aliceblue: 0xf0f8ff,\n  antiquewhite: 0xfaebd7,\n  aqua: 0x00ffff,\n  aquamarine: 0x7fffd4,\n  azure: 0xf0ffff,\n  beige: 0xf5f5dc,\n  bisque: 0xffe4c4,\n  black: 0x000000,\n  blanchedalmond: 0xffebcd,\n  blue: 0x0000ff,\n  blueviolet: 0x8a2be2,\n  brown: 0xa52a2a,\n  burlywood: 0xdeb887,\n  cadetblue: 0x5f9ea0,\n  chartreuse: 0x7fff00,\n  chocolate: 0xd2691e,\n  coral: 0xff7f50,\n  cornflowerblue: 0x6495ed,\n  cornsilk: 0xfff8dc,\n  crimson: 0xdc143c,\n  cyan: 0x00ffff,\n  darkblue: 0x00008b,\n  darkcyan: 0x008b8b,\n  darkgoldenrod: 0xb8860b,\n  darkgray: 0xa9a9a9,\n  darkgreen: 0x006400,\n  darkgrey: 0xa9a9a9,\n  darkkhaki: 0xbdb76b,\n  darkmagenta: 0x8b008b,\n  darkolivegreen: 0x556b2f,\n  darkorange: 0xff8c00,\n  darkorchid: 0x9932cc,\n  darkred: 0x8b0000,\n  darksalmon: 0xe9967a,\n  darkseagreen: 0x8fbc8f,\n  darkslateblue: 0x483d8b,\n  darkslategray: 0x2f4f4f,\n  darkslategrey: 0x2f4f4f,\n  darkturquoise: 0x00ced1,\n  darkviolet: 0x9400d3,\n  deeppink: 0xff1493,\n  deepskyblue: 0x00bfff,\n  dimgray: 0x696969,\n  dimgrey: 0x696969,\n  dodgerblue: 0x1e90ff,\n  firebrick: 0xb22222,\n  floralwhite: 0xfffaf0,\n  forestgreen: 0x228b22,\n  fuchsia: 0xff00ff,\n  gainsboro: 0xdcdcdc,\n  ghostwhite: 0xf8f8ff,\n  gold: 0xffd700,\n  goldenrod: 0xdaa520,\n  gray: 0x808080,\n  green: 0x008000,\n  greenyellow: 0xadff2f,\n  grey: 0x808080,\n  honeydew: 0xf0fff0,\n  hotpink: 0xff69b4,\n  indianred: 0xcd5c5c,\n  indigo: 0x4b0082,\n  ivory: 0xfffff0,\n  khaki: 0xf0e68c,\n  lavender: 0xe6e6fa,\n  lavenderblush: 0xfff0f5,\n  lawngreen: 0x7cfc00,\n  lemonchiffon: 0xfffacd,\n  lightblue: 0xadd8e6,\n  lightcoral: 0xf08080,\n  lightcyan: 0xe0ffff,\n  lightgoldenrodyellow: 0xfafad2,\n  lightgray: 0xd3d3d3,\n  lightgreen: 0x90ee90,\n  lightgrey: 0xd3d3d3,\n  lightpink: 0xffb6c1,\n  lightsalmon: 0xffa07a,\n  lightseagreen: 0x20b2aa,\n  lightskyblue: 0x87cefa,\n  lightslategray: 0x778899,\n  lightslategrey: 0x778899,\n  lightsteelblue: 0xb0c4de,\n  lightyellow: 0xffffe0,\n  lime: 0x00ff00,\n  limegreen: 0x32cd32,\n  linen: 0xfaf0e6,\n  magenta: 0xff00ff,\n  maroon: 0x800000,\n  mediumaquamarine: 0x66cdaa,\n  mediumblue: 0x0000cd,\n  mediumorchid: 0xba55d3,\n  mediumpurple: 0x9370db,\n  mediumseagreen: 0x3cb371,\n  mediumslateblue: 0x7b68ee,\n  mediumspringgreen: 0x00fa9a,\n  mediumturquoise: 0x48d1cc,\n  mediumvioletred: 0xc71585,\n  midnightblue: 0x191970,\n  mintcream: 0xf5fffa,\n  mistyrose: 0xffe4e1,\n  moccasin: 0xffe4b5,\n  navajowhite: 0xffdead,\n  navy: 0x000080,\n  oldlace: 0xfdf5e6,\n  olive: 0x808000,\n  olivedrab: 0x6b8e23,\n  orange: 0xffa500,\n  orangered: 0xff4500,\n  orchid: 0xda70d6,\n  palegoldenrod: 0xeee8aa,\n  palegreen: 0x98fb98,\n  paleturquoise: 0xafeeee,\n  palevioletred: 0xdb7093,\n  papayawhip: 0xffefd5,\n  peachpuff: 0xffdab9,\n  peru: 0xcd853f,\n  pink: 0xffc0cb,\n  plum: 0xdda0dd,\n  powderblue: 0xb0e0e6,\n  purple: 0x800080,\n  rebeccapurple: 0x663399,\n  red: 0xff0000,\n  rosybrown: 0xbc8f8f,\n  royalblue: 0x4169e1,\n  saddlebrown: 0x8b4513,\n  salmon: 0xfa8072,\n  sandybrown: 0xf4a460,\n  seagreen: 0x2e8b57,\n  seashell: 0xfff5ee,\n  sienna: 0xa0522d,\n  silver: 0xc0c0c0,\n  skyblue: 0x87ceeb,\n  slateblue: 0x6a5acd,\n  slategray: 0x708090,\n  slategrey: 0x708090,\n  snow: 0xfffafa,\n  springgreen: 0x00ff7f,\n  steelblue: 0x4682b4,\n  tan: 0xd2b48c,\n  teal: 0x008080,\n  thistle: 0xd8bfd8,\n  tomato: 0xff6347,\n  turquoise: 0x40e0d0,\n  violet: 0xee82ee,\n  wheat: 0xf5deb3,\n  white: 0xffffff,\n  whitesmoke: 0xf5f5f5,\n  yellow: 0xffff00,\n  yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n  copy(channels) {\n    return Object.assign(new this.constructor, this, channels);\n  },\n  displayable() {\n    return this.rgb().displayable();\n  },\n  hex: color_formatHex, // Deprecated! Use color.formatHex.\n  formatHex: color_formatHex,\n  formatHex8: color_formatHex8,\n  formatHsl: color_formatHsl,\n  formatRgb: color_formatRgb,\n  toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n  return this.rgb().formatHex();\n}\n\nfunction color_formatHex8() {\n  return this.rgb().formatHex8();\n}\n\nfunction color_formatHsl() {\n  return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n  return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n  var m, l;\n  format = (format + \"\").trim().toLowerCase();\n  return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n      : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n      : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n      : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n      : null) // invalid hex\n      : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n      : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n      : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n      : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n      : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n      : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n      : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n      : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n      : null;\n}\n\nfunction rgbn(n) {\n  return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n  if (a <= 0) r = g = b = NaN;\n  return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Rgb;\n  o = o.rgb();\n  return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n  return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n  this.r = +r;\n  this.g = +g;\n  this.b = +b;\n  this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n  brighter(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  darker(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  rgb() {\n    return this;\n  },\n  clamp() {\n    return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n  },\n  displayable() {\n    return (-0.5 <= this.r && this.r < 255.5)\n        && (-0.5 <= this.g && this.g < 255.5)\n        && (-0.5 <= this.b && this.b < 255.5)\n        && (0 <= this.opacity && this.opacity <= 1);\n  },\n  hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n  formatHex: rgb_formatHex,\n  formatHex8: rgb_formatHex8,\n  formatRgb: rgb_formatRgb,\n  toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n  return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n  return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n  const a = clampa(this.opacity);\n  return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n  return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n  return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n  value = clampi(value);\n  return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n  if (a <= 0) h = s = l = NaN;\n  else if (l <= 0 || l >= 1) h = s = NaN;\n  else if (s <= 0) h = NaN;\n  return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n  if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Hsl;\n  if (o instanceof Hsl) return o;\n  o = o.rgb();\n  var r = o.r / 255,\n      g = o.g / 255,\n      b = o.b / 255,\n      min = Math.min(r, g, b),\n      max = Math.max(r, g, b),\n      h = NaN,\n      s = max - min,\n      l = (max + min) / 2;\n  if (s) {\n    if (r === max) h = (g - b) / s + (g < b) * 6;\n    else if (g === max) h = (b - r) / s + 2;\n    else h = (r - g) / s + 4;\n    s /= l < 0.5 ? max + min : 2 - max - min;\n    h *= 60;\n  } else {\n    s = l > 0 && l < 1 ? 0 : h;\n  }\n  return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n  return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n  this.h = +h;\n  this.s = +s;\n  this.l = +l;\n  this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n  brighter(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  darker(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  rgb() {\n    var h = this.h % 360 + (this.h < 0) * 360,\n        s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n        l = this.l,\n        m2 = l + (l < 0.5 ? l : 1 - l) * s,\n        m1 = 2 * l - m2;\n    return new Rgb(\n      hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n      hsl2rgb(h, m1, m2),\n      hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n      this.opacity\n    );\n  },\n  clamp() {\n    return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n  },\n  displayable() {\n    return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n        && (0 <= this.l && this.l <= 1)\n        && (0 <= this.opacity && this.opacity <= 1);\n  },\n  formatHsl() {\n    const a = clampa(this.opacity);\n    return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n  }\n}));\n\nfunction clamph(value) {\n  value = (value || 0) % 360;\n  return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n  return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n  return (h < 60 ? m1 + (m2 - m1) * h / 60\n      : h < 180 ? m2\n      : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n      : m1) * 255;\n}\n","export default x => () => x;\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n  return function(t) {\n    return a + t * d;\n  };\n}\n\nfunction exponential(a, b, y) {\n  return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n    return Math.pow(a + t * b, y);\n  };\n}\n\nexport function hue(a, b) {\n  var d = b - a;\n  return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n  return (y = +y) === 1 ? nogamma : function(a, b) {\n    return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n  };\n}\n\nexport default function nogamma(a, b) {\n  var d = b - a;\n  return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n  var color = gamma(y);\n\n  function rgb(start, end) {\n    var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n        g = color(start.g, end.g),\n        b = color(start.b, end.b),\n        opacity = nogamma(start.opacity, end.opacity);\n    return function(t) {\n      start.r = r(t);\n      start.g = g(t);\n      start.b = b(t);\n      start.opacity = opacity(t);\n      return start + \"\";\n    };\n  }\n\n  rgb.gamma = rgbGamma;\n\n  return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n  return function(colors) {\n    var n = colors.length,\n        r = new Array(n),\n        g = new Array(n),\n        b = new Array(n),\n        i, color;\n    for (i = 0; i < n; ++i) {\n      color = colorRgb(colors[i]);\n      r[i] = color.r || 0;\n      g[i] = color.g || 0;\n      b[i] = color.b || 0;\n    }\n    r = spline(r);\n    g = spline(g);\n    b = spline(b);\n    color.opacity = 1;\n    return function(t) {\n      color.r = r(t);\n      color.g = g(t);\n      color.b = b(t);\n      return color + \"\";\n    };\n  };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","export default function(a, b) {\n  return a = +a, b = +b, function(t) {\n    return a * (1 - t) + b * t;\n  };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n    reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n  return function() {\n    return b;\n  };\n}\n\nfunction one(b) {\n  return function(t) {\n    return b(t) + \"\";\n  };\n}\n\nexport default function(a, b) {\n  var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n      am, // current match in a\n      bm, // current match in b\n      bs, // string preceding current number in b, if any\n      i = -1, // index in s\n      s = [], // string constants and placeholders\n      q = []; // number interpolators\n\n  // Coerce inputs to strings.\n  a = a + \"\", b = b + \"\";\n\n  // Interpolate pairs of numbers in a & b.\n  while ((am = reA.exec(a))\n      && (bm = reB.exec(b))) {\n    if ((bs = bm.index) > bi) { // a string precedes the next number in b\n      bs = b.slice(bi, bs);\n      if (s[i]) s[i] += bs; // coalesce with previous string\n      else s[++i] = bs;\n    }\n    if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n      if (s[i]) s[i] += bm; // coalesce with previous string\n      else s[++i] = bm;\n    } else { // interpolate non-matching numbers\n      s[++i] = null;\n      q.push({i: i, x: number(am, bm)});\n    }\n    bi = reB.lastIndex;\n  }\n\n  // Add remains of b.\n  if (bi < b.length) {\n    bs = b.slice(bi);\n    if (s[i]) s[i] += bs; // coalesce with previous string\n    else s[++i] = bs;\n  }\n\n  // Special optimization for only a single match.\n  // Otherwise, interpolate each of the numbers and rejoin the string.\n  return s.length < 2 ? (q[0]\n      ? one(q[0].x)\n      : zero(b))\n      : (b = q.length, function(t) {\n          for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n          return s.join(\"\");\n        });\n}\n","var degrees = 180 / Math.PI;\n\nexport var identity = {\n  translateX: 0,\n  translateY: 0,\n  rotate: 0,\n  skewX: 0,\n  scaleX: 1,\n  scaleY: 1\n};\n\nexport default function(a, b, c, d, e, f) {\n  var scaleX, scaleY, skewX;\n  if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n  if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n  if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n  if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n  return {\n    translateX: e,\n    translateY: f,\n    rotate: Math.atan2(b, a) * degrees,\n    skewX: Math.atan(skewX) * degrees,\n    scaleX: scaleX,\n    scaleY: scaleY\n  };\n}\n","import decompose, {identity} from \"./decompose.js\";\n\nvar svgNode;\n\n/* eslint-disable no-undef */\nexport function parseCss(value) {\n  const m = new (typeof DOMMatrix === \"function\" ? DOMMatrix : WebKitCSSMatrix)(value + \"\");\n  return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);\n}\n\nexport function parseSvg(value) {\n  if (value == null) return identity;\n  if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n  svgNode.setAttribute(\"transform\", value);\n  if (!(value = svgNode.transform.baseVal.consolidate())) return identity;\n  value = value.matrix;\n  return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n}\n","import number from \"../number.js\";\nimport {parseCss, parseSvg} from \"./parse.js\";\n\nfunction interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n  function pop(s) {\n    return s.length ? s.pop() + \" \" : \"\";\n  }\n\n  function translate(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n      q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n    } else if (xb || yb) {\n      s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n    }\n  }\n\n  function rotate(a, b, s, q) {\n    if (a !== b) {\n      if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n      q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: number(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"rotate(\" + b + degParen);\n    }\n  }\n\n  function skewX(a, b, s, q) {\n    if (a !== b) {\n      q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: number(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"skewX(\" + b + degParen);\n    }\n  }\n\n  function scale(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n      q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n    } else if (xb !== 1 || yb !== 1) {\n      s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n    }\n  }\n\n  return function(a, b) {\n    var s = [], // string constants and placeholders\n        q = []; // number interpolators\n    a = parse(a), b = parse(b);\n    translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n    rotate(a.rotate, b.rotate, s, q);\n    skewX(a.skewX, b.skewX, s, q);\n    scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n    a = b = null; // gc\n    return function(t) {\n      var i = -1, n = q.length, o;\n      while (++i < n) s[(o = q[i]).i] = o.x(t);\n      return s.join(\"\");\n    };\n  };\n}\n\nexport var interpolateTransformCss = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\nexport var interpolateTransformSvg = interpolateTransform(parseSvg, \", \", \")\", \")\");\n","var frame = 0, // is an animation frame pending?\n    timeout = 0, // is a timeout pending?\n    interval = 0, // are any timers active?\n    pokeDelay = 1000, // how frequently we check for clock skew\n    taskHead,\n    taskTail,\n    clockLast = 0,\n    clockNow = 0,\n    clockSkew = 0,\n    clock = typeof performance === \"object\" && performance.now ? performance : Date,\n    setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n  return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n  clockNow = 0;\n}\n\nexport function Timer() {\n  this._call =\n  this._time =\n  this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n  constructor: Timer,\n  restart: function(callback, delay, time) {\n    if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n    time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n    if (!this._next && taskTail !== this) {\n      if (taskTail) taskTail._next = this;\n      else taskHead = this;\n      taskTail = this;\n    }\n    this._call = callback;\n    this._time = time;\n    sleep();\n  },\n  stop: function() {\n    if (this._call) {\n      this._call = null;\n      this._time = Infinity;\n      sleep();\n    }\n  }\n};\n\nexport function timer(callback, delay, time) {\n  var t = new Timer;\n  t.restart(callback, delay, time);\n  return t;\n}\n\nexport function timerFlush() {\n  now(); // Get the current time, if not already set.\n  ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n  var t = taskHead, e;\n  while (t) {\n    if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);\n    t = t._next;\n  }\n  --frame;\n}\n\nfunction wake() {\n  clockNow = (clockLast = clock.now()) + clockSkew;\n  frame = timeout = 0;\n  try {\n    timerFlush();\n  } finally {\n    frame = 0;\n    nap();\n    clockNow = 0;\n  }\n}\n\nfunction poke() {\n  var now = clock.now(), delay = now - clockLast;\n  if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n  var t0, t1 = taskHead, t2, time = Infinity;\n  while (t1) {\n    if (t1._call) {\n      if (time > t1._time) time = t1._time;\n      t0 = t1, t1 = t1._next;\n    } else {\n      t2 = t1._next, t1._next = null;\n      t1 = t0 ? t0._next = t2 : taskHead = t2;\n    }\n  }\n  taskTail = t0;\n  sleep(time);\n}\n\nfunction sleep(time) {\n  if (frame) return; // Soonest alarm already set, or will be.\n  if (timeout) timeout = clearTimeout(timeout);\n  var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n  if (delay > 24) {\n    if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n    if (interval) interval = clearInterval(interval);\n  } else {\n    if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n    frame = 1, setFrame(wake);\n  }\n}\n","import {Timer} from \"./timer.js\";\n\nexport default function(callback, delay, time) {\n  var t = new Timer;\n  delay = delay == null ? 0 : +delay;\n  t.restart(elapsed => {\n    t.stop();\n    callback(elapsed + delay);\n  }, delay, time);\n  return t;\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {timer, timeout} from \"d3-timer\";\n\nvar emptyOn = dispatch(\"start\", \"end\", \"cancel\", \"interrupt\");\nvar emptyTween = [];\n\nexport var CREATED = 0;\nexport var SCHEDULED = 1;\nexport var STARTING = 2;\nexport var STARTED = 3;\nexport var RUNNING = 4;\nexport var ENDING = 5;\nexport var ENDED = 6;\n\nexport default function(node, name, id, index, group, timing) {\n  var schedules = node.__transition;\n  if (!schedules) node.__transition = {};\n  else if (id in schedules) return;\n  create(node, id, {\n    name: name,\n    index: index, // For context during callback.\n    group: group, // For context during callback.\n    on: emptyOn,\n    tween: emptyTween,\n    time: timing.time,\n    delay: timing.delay,\n    duration: timing.duration,\n    ease: timing.ease,\n    timer: null,\n    state: CREATED\n  });\n}\n\nexport function init(node, id) {\n  var schedule = get(node, id);\n  if (schedule.state > CREATED) throw new Error(\"too late; already scheduled\");\n  return schedule;\n}\n\nexport function set(node, id) {\n  var schedule = get(node, id);\n  if (schedule.state > STARTED) throw new Error(\"too late; already running\");\n  return schedule;\n}\n\nexport function get(node, id) {\n  var schedule = node.__transition;\n  if (!schedule || !(schedule = schedule[id])) throw new Error(\"transition not found\");\n  return schedule;\n}\n\nfunction create(node, id, self) {\n  var schedules = node.__transition,\n      tween;\n\n  // Initialize the self timer when the transition is created.\n  // Note the actual delay is not known until the first callback!\n  schedules[id] = self;\n  self.timer = timer(schedule, 0, self.time);\n\n  function schedule(elapsed) {\n    self.state = SCHEDULED;\n    self.timer.restart(start, self.delay, self.time);\n\n    // If the elapsed delay is less than our first sleep, start immediately.\n    if (self.delay <= elapsed) start(elapsed - self.delay);\n  }\n\n  function start(elapsed) {\n    var i, j, n, o;\n\n    // If the state is not SCHEDULED, then we previously errored on start.\n    if (self.state !== SCHEDULED) return stop();\n\n    for (i in schedules) {\n      o = schedules[i];\n      if (o.name !== self.name) continue;\n\n      // While this element already has a starting transition during this frame,\n      // defer starting an interrupting transition until that transition has a\n      // chance to tick (and possibly end); see d3/d3-transition#54!\n      if (o.state === STARTED) return timeout(start);\n\n      // Interrupt the active transition, if any.\n      if (o.state === RUNNING) {\n        o.state = ENDED;\n        o.timer.stop();\n        o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n        delete schedules[i];\n      }\n\n      // Cancel any pre-empted transitions.\n      else if (+i < id) {\n        o.state = ENDED;\n        o.timer.stop();\n        o.on.call(\"cancel\", node, node.__data__, o.index, o.group);\n        delete schedules[i];\n      }\n    }\n\n    // Defer the first tick to end of the current frame; see d3/d3#1576.\n    // Note the transition may be canceled after start and before the first tick!\n    // Note this must be scheduled before the start event; see d3/d3-transition#16!\n    // Assuming this is successful, subsequent callbacks go straight to tick.\n    timeout(function() {\n      if (self.state === STARTED) {\n        self.state = RUNNING;\n        self.timer.restart(tick, self.delay, self.time);\n        tick(elapsed);\n      }\n    });\n\n    // Dispatch the start event.\n    // Note this must be done before the tween are initialized.\n    self.state = STARTING;\n    self.on.call(\"start\", node, node.__data__, self.index, self.group);\n    if (self.state !== STARTING) return; // interrupted\n    self.state = STARTED;\n\n    // Initialize the tween, deleting null tween.\n    tween = new Array(n = self.tween.length);\n    for (i = 0, j = -1; i < n; ++i) {\n      if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n        tween[++j] = o;\n      }\n    }\n    tween.length = j + 1;\n  }\n\n  function tick(elapsed) {\n    var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),\n        i = -1,\n        n = tween.length;\n\n    while (++i < n) {\n      tween[i].call(node, t);\n    }\n\n    // Dispatch the end event.\n    if (self.state === ENDING) {\n      self.on.call(\"end\", node, node.__data__, self.index, self.group);\n      stop();\n    }\n  }\n\n  function stop() {\n    self.state = ENDED;\n    self.timer.stop();\n    delete schedules[id];\n    for (var i in schedules) return; // eslint-disable-line no-unused-vars\n    delete node.__transition;\n  }\n}\n","import {STARTING, ENDING, ENDED} from \"./transition/schedule.js\";\n\nexport default function(node, name) {\n  var schedules = node.__transition,\n      schedule,\n      active,\n      empty = true,\n      i;\n\n  if (!schedules) return;\n\n  name = name == null ? null : name + \"\";\n\n  for (i in schedules) {\n    if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n    active = schedule.state > STARTING && schedule.state < ENDING;\n    schedule.state = ENDED;\n    schedule.timer.stop();\n    schedule.on.call(active ? \"interrupt\" : \"cancel\", node, node.__data__, schedule.index, schedule.group);\n    delete schedules[i];\n  }\n\n  if (empty) delete node.__transition;\n}\n","import interrupt from \"../interrupt.js\";\n\nexport default function(name) {\n  return this.each(function() {\n    interrupt(this, name);\n  });\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction tweenRemove(id, name) {\n  var tween0, tween1;\n  return function() {\n    var schedule = set(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = tween0 = tween;\n      for (var i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1 = tween1.slice();\n          tween1.splice(i, 1);\n          break;\n        }\n      }\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nfunction tweenFunction(id, name, value) {\n  var tween0, tween1;\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    var schedule = set(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = (tween0 = tween).slice();\n      for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1[i] = t;\n          break;\n        }\n      }\n      if (i === n) tween1.push(t);\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nexport default function(name, value) {\n  var id = this._id;\n\n  name += \"\";\n\n  if (arguments.length < 2) {\n    var tween = get(this.node(), id).tween;\n    for (var i = 0, n = tween.length, t; i < n; ++i) {\n      if ((t = tween[i]).name === name) {\n        return t.value;\n      }\n    }\n    return null;\n  }\n\n  return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n}\n\nexport function tweenValue(transition, name, value) {\n  var id = transition._id;\n\n  transition.each(function() {\n    var schedule = set(this, id);\n    (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n  });\n\n  return function(node) {\n    return get(node, id).value[name];\n  };\n}\n","import {color} from \"d3-color\";\nimport {interpolateNumber, interpolateRgb, interpolateString} from \"d3-interpolate\";\n\nexport default function(a, b) {\n  var c;\n  return (typeof b === \"number\" ? interpolateNumber\n      : b instanceof color ? interpolateRgb\n      : (c = color(b)) ? (b = c, interpolateRgb)\n      : interpolateString)(a, b);\n}\n","import {interpolateTransformSvg as interpolateTransform} from \"d3-interpolate\";\nimport {namespace} from \"d3-selection\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction attrRemove(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant(name, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = this.getAttribute(name);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction attrConstantNS(fullname, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = this.getAttributeNS(fullname.space, fullname.local);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction attrFunction(name, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0, value1 = value(this), string1;\n    if (value1 == null) return void this.removeAttribute(name);\n    string0 = this.getAttribute(name);\n    string1 = value1 + \"\";\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nfunction attrFunctionNS(fullname, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0, value1 = value(this), string1;\n    if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n    string0 = this.getAttributeNS(fullname.space, fullname.local);\n    string1 = value1 + \"\";\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nexport default function(name, value) {\n  var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform : interpolate;\n  return this.attrTween(name, typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n      : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname)\n      : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));\n}\n","import {namespace} from \"d3-selection\";\n\nfunction attrInterpolate(name, i) {\n  return function(t) {\n    this.setAttribute(name, i.call(this, t));\n  };\n}\n\nfunction attrInterpolateNS(fullname, i) {\n  return function(t) {\n    this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));\n  };\n}\n\nfunction attrTweenNS(fullname, value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nfunction attrTween(name, value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(name, value) {\n  var key = \"attr.\" + name;\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  var fullname = namespace(name);\n  return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n}\n","import {get, init} from \"./schedule.js\";\n\nfunction delayFunction(id, value) {\n  return function() {\n    init(this, id).delay = +value.apply(this, arguments);\n  };\n}\n\nfunction delayConstant(id, value) {\n  return value = +value, function() {\n    init(this, id).delay = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? delayFunction\n          : delayConstant)(id, value))\n      : get(this.node(), id).delay;\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction durationFunction(id, value) {\n  return function() {\n    set(this, id).duration = +value.apply(this, arguments);\n  };\n}\n\nfunction durationConstant(id, value) {\n  return value = +value, function() {\n    set(this, id).duration = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? durationFunction\n          : durationConstant)(id, value))\n      : get(this.node(), id).duration;\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction easeConstant(id, value) {\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    set(this, id).ease = value;\n  };\n}\n\nexport default function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each(easeConstant(id, value))\n      : get(this.node(), id).ease;\n}\n","import {set} from \"./schedule.js\";\n\nfunction easeVarying(id, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (typeof v !== \"function\") throw new Error;\n    set(this, id).ease = v;\n  };\n}\n\nexport default function(value) {\n  if (typeof value !== \"function\") throw new Error;\n  return this.each(easeVarying(this._id, value));\n}\n","import {matcher} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\n\nexport default function(match) {\n  if (typeof match !== \"function\") match = matcher(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, this._name, this._id);\n}\n","import {Transition} from \"./index.js\";\n\nexport default function(transition) {\n  if (transition._id !== this._id) throw new Error;\n\n  for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Transition(merges, this._parents, this._name, this._id);\n}\n","import {get, set, init} from \"./schedule.js\";\n\nfunction start(name) {\n  return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n    var i = t.indexOf(\".\");\n    if (i >= 0) t = t.slice(0, i);\n    return !t || t === \"start\";\n  });\n}\n\nfunction onFunction(id, name, listener) {\n  var on0, on1, sit = start(name) ? init : set;\n  return function() {\n    var schedule = sit(this, id),\n        on = schedule.on;\n\n    // If this node shared a dispatch with the previous node,\n    // just assign the updated shared dispatch and we’re done!\n    // Otherwise, copy-on-write.\n    if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n    schedule.on = on1;\n  };\n}\n\nexport default function(name, listener) {\n  var id = this._id;\n\n  return arguments.length < 2\n      ? get(this.node(), id).on.on(name)\n      : this.each(onFunction(id, name, listener));\n}\n","function removeFunction(id) {\n  return function() {\n    var parent = this.parentNode;\n    for (var i in this.__transition) if (+i !== id) return;\n    if (parent) parent.removeChild(this);\n  };\n}\n\nexport default function() {\n  return this.on(\"end.remove\", removeFunction(this._id));\n}\n","import {selector} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select !== \"function\") select = selector(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n        schedule(subgroup[i], name, id, i, subgroup, get(node, id));\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, name, id);\n}\n","import {selectorAll} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select !== \"function\") select = selectorAll(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {\n          if (child = children[k]) {\n            schedule(child, name, id, k, children, inherit);\n          }\n        }\n        subgroups.push(children);\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, parents, name, id);\n}\n","import {selection} from \"d3-selection\";\n\nvar Selection = selection.prototype.constructor;\n\nexport default function() {\n  return new Selection(this._groups, this._parents);\n}\n","import {interpolateTransformCss as interpolateTransform} from \"d3-interpolate\";\nimport {style} from \"d3-selection\";\nimport {set} from \"./schedule.js\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction styleNull(name, interpolate) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0 = style(this, name),\n        string1 = (this.style.removeProperty(name), style(this, name));\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, string10 = string1);\n  };\n}\n\nfunction styleRemove(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant(name, interpolate, value1) {\n  var string00,\n      string1 = value1 + \"\",\n      interpolate0;\n  return function() {\n    var string0 = style(this, name);\n    return string0 === string1 ? null\n        : string0 === string00 ? interpolate0\n        : interpolate0 = interpolate(string00 = string0, value1);\n  };\n}\n\nfunction styleFunction(name, interpolate, value) {\n  var string00,\n      string10,\n      interpolate0;\n  return function() {\n    var string0 = style(this, name),\n        value1 = value(this),\n        string1 = value1 + \"\";\n    if (value1 == null) string1 = value1 = (this.style.removeProperty(name), style(this, name));\n    return string0 === string1 ? null\n        : string0 === string00 && string1 === string10 ? interpolate0\n        : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n  };\n}\n\nfunction styleMaybeRemove(id, name) {\n  var on0, on1, listener0, key = \"style.\" + name, event = \"end.\" + key, remove;\n  return function() {\n    var schedule = set(this, id),\n        on = schedule.on,\n        listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;\n\n    // If this node shared a dispatch with the previous node,\n    // just assign the updated shared dispatch and we’re done!\n    // Otherwise, copy-on-write.\n    if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);\n\n    schedule.on = on1;\n  };\n}\n\nexport default function(name, value, priority) {\n  var i = (name += \"\") === \"transform\" ? interpolateTransform : interpolate;\n  return value == null ? this\n      .styleTween(name, styleNull(name, i))\n      .on(\"end.style.\" + name, styleRemove(name))\n    : typeof value === \"function\" ? this\n      .styleTween(name, styleFunction(name, i, tweenValue(this, \"style.\" + name, value)))\n      .each(styleMaybeRemove(this._id, name))\n    : this\n      .styleTween(name, styleConstant(name, i, value), priority)\n      .on(\"end.style.\" + name, null);\n}\n","function styleInterpolate(name, i, priority) {\n  return function(t) {\n    this.style.setProperty(name, i.call(this, t), priority);\n  };\n}\n\nfunction styleTween(name, value, priority) {\n  var t, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);\n    return t;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(name, value, priority) {\n  var key = \"style.\" + (name += \"\");\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n}\n","import {tweenValue} from \"./tween.js\";\n\nfunction textConstant(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction(value) {\n  return function() {\n    var value1 = value(this);\n    this.textContent = value1 == null ? \"\" : value1;\n  };\n}\n\nexport default function(value) {\n  return this.tween(\"text\", typeof value === \"function\"\n      ? textFunction(tweenValue(this, \"text\", value))\n      : textConstant(value == null ? \"\" : value + \"\"));\n}\n","function textInterpolate(i) {\n  return function(t) {\n    this.textContent = i.call(this, t);\n  };\n}\n\nfunction textTween(value) {\n  var t0, i0;\n  function tween() {\n    var i = value.apply(this, arguments);\n    if (i !== i0) t0 = (i0 = i) && textInterpolate(i);\n    return t0;\n  }\n  tween._value = value;\n  return tween;\n}\n\nexport default function(value) {\n  var key = \"text\";\n  if (arguments.length < 1) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  return this.tween(key, textTween(value));\n}\n","import {Transition, newId} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function() {\n  var name = this._name,\n      id0 = this._id,\n      id1 = newId();\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        var inherit = get(node, id0);\n        schedule(node, name, id1, i, group, {\n          time: inherit.time + inherit.delay + inherit.duration,\n          delay: 0,\n          duration: inherit.duration,\n          ease: inherit.ease\n        });\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id1);\n}\n","import {set} from \"./schedule.js\";\n\nexport default function() {\n  var on0, on1, that = this, id = that._id, size = that.size();\n  return new Promise(function(resolve, reject) {\n    var cancel = {value: reject},\n        end = {value: function() { if (--size === 0) resolve(); }};\n\n    that.each(function() {\n      var schedule = set(this, id),\n          on = schedule.on;\n\n      // If this node shared a dispatch with the previous node,\n      // just assign the updated shared dispatch and we’re done!\n      // Otherwise, copy-on-write.\n      if (on !== on0) {\n        on1 = (on0 = on).copy();\n        on1._.cancel.push(cancel);\n        on1._.interrupt.push(cancel);\n        on1._.end.push(end);\n      }\n\n      schedule.on = on1;\n    });\n\n    // The selection was empty, resolve end immediately\n    if (size === 0) resolve();\n  });\n}\n","import {selection} from \"d3-selection\";\nimport transition_attr from \"./attr.js\";\nimport transition_attrTween from \"./attrTween.js\";\nimport transition_delay from \"./delay.js\";\nimport transition_duration from \"./duration.js\";\nimport transition_ease from \"./ease.js\";\nimport transition_easeVarying from \"./easeVarying.js\";\nimport transition_filter from \"./filter.js\";\nimport transition_merge from \"./merge.js\";\nimport transition_on from \"./on.js\";\nimport transition_remove from \"./remove.js\";\nimport transition_select from \"./select.js\";\nimport transition_selectAll from \"./selectAll.js\";\nimport transition_selection from \"./selection.js\";\nimport transition_style from \"./style.js\";\nimport transition_styleTween from \"./styleTween.js\";\nimport transition_text from \"./text.js\";\nimport transition_textTween from \"./textTween.js\";\nimport transition_transition from \"./transition.js\";\nimport transition_tween from \"./tween.js\";\nimport transition_end from \"./end.js\";\n\nvar id = 0;\n\nexport function Transition(groups, parents, name, id) {\n  this._groups = groups;\n  this._parents = parents;\n  this._name = name;\n  this._id = id;\n}\n\nexport default function transition(name) {\n  return selection().transition(name);\n}\n\nexport function newId() {\n  return ++id;\n}\n\nvar selection_prototype = selection.prototype;\n\nTransition.prototype = transition.prototype = {\n  constructor: Transition,\n  select: transition_select,\n  selectAll: transition_selectAll,\n  selectChild: selection_prototype.selectChild,\n  selectChildren: selection_prototype.selectChildren,\n  filter: transition_filter,\n  merge: transition_merge,\n  selection: transition_selection,\n  transition: transition_transition,\n  call: selection_prototype.call,\n  nodes: selection_prototype.nodes,\n  node: selection_prototype.node,\n  size: selection_prototype.size,\n  empty: selection_prototype.empty,\n  each: selection_prototype.each,\n  on: transition_on,\n  attr: transition_attr,\n  attrTween: transition_attrTween,\n  style: transition_style,\n  styleTween: transition_styleTween,\n  text: transition_text,\n  textTween: transition_textTween,\n  remove: transition_remove,\n  tween: transition_tween,\n  delay: transition_delay,\n  duration: transition_duration,\n  ease: transition_ease,\n  easeVarying: transition_easeVarying,\n  end: transition_end,\n  [Symbol.iterator]: selection_prototype[Symbol.iterator]\n};\n","export function cubicIn(t) {\n  return t * t * t;\n}\n\nexport function cubicOut(t) {\n  return --t * t * t + 1;\n}\n\nexport function cubicInOut(t) {\n  return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n","import {Transition, newId} from \"../transition/index.js\";\nimport schedule from \"../transition/schedule.js\";\nimport {easeCubicInOut} from \"d3-ease\";\nimport {now} from \"d3-timer\";\n\nvar defaultTiming = {\n  time: null, // Set on use.\n  delay: 0,\n  duration: 250,\n  ease: easeCubicInOut\n};\n\nfunction inherit(node, id) {\n  var timing;\n  while (!(timing = node.__transition) || !(timing = timing[id])) {\n    if (!(node = node.parentNode)) {\n      throw new Error(`transition ${id} not found`);\n    }\n  }\n  return timing;\n}\n\nexport default function(name) {\n  var id,\n      timing;\n\n  if (name instanceof Transition) {\n    id = name._id, name = name._name;\n  } else {\n    id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n  }\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        schedule(node, name, id, i, group, timing || inherit(node, id));\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id);\n}\n","import {selection} from \"d3-selection\";\nimport selection_interrupt from \"./interrupt.js\";\nimport selection_transition from \"./transition.js\";\n\nselection.prototype.interrupt = selection_interrupt;\nselection.prototype.transition = selection_transition;\n","export function Transform(k, x, y) {\n  this.k = k;\n  this.x = x;\n  this.y = y;\n}\n\nTransform.prototype = {\n  constructor: Transform,\n  scale: function(k) {\n    return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n  },\n  translate: function(x, y) {\n    return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n  },\n  apply: function(point) {\n    return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n  },\n  applyX: function(x) {\n    return x * this.k + this.x;\n  },\n  applyY: function(y) {\n    return y * this.k + this.y;\n  },\n  invert: function(location) {\n    return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n  },\n  invertX: function(x) {\n    return (x - this.x) / this.k;\n  },\n  invertY: function(y) {\n    return (y - this.y) / this.k;\n  },\n  rescaleX: function(x) {\n    return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n  },\n  rescaleY: function(y) {\n    return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n  },\n  toString: function() {\n    return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n  }\n};\n\nexport var identity = new Transform(1, 0, 0);\n\ntransform.prototype = Transform.prototype;\n\nexport default function transform(node) {\n  while (!node.__zoom) if (!(node = node.parentNode)) return identity;\n  return node.__zoom;\n}\n","\n/*\n  HTDMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    k = discount factor (0, Infinity)\n\n  Behavioral variables:\n    A = amount\n    D = delay\n    V = subjective value\n\n  Equations:\n    V = A / (1 + kD)\n    k = (A - V) / (VD)\n*/\nexport default class HTDMath {\n  static k = {\n    DEFAULT: 0.05,\n    MIN: 0,\n    MAX: 100,\n    STEP: 0.001,\n    JUMP: 0.01,\n  };\n\n  static adk2v(a, d, k) {\n    return a / (1 + k * d);\n  }\n\n  static adv2k(a, d, v) {\n    return (a - v) / (v * d);\n  }\n}\n","\n// Internal dependencies\nimport HTDMath from './htd-math';\n\nexport default HTDMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\n// Needed for d3 in WebWorker!\nimport 'regenerator-runtime/runtime';\n\nimport * as BayesDistributions from 'bayes.js/distributions';\nimport * as BayesMcmc from 'bayes.js/mcmc';\nimport * as d3 from 'd3';\nimport HTDMath from '@decidables/discountable-math';\n\nself.onmessage = (event) => {\n  const params = {\n    k: {type: 'real', lower: HTDMath.k.MIN, upper: HTDMath.k.MAX},\n    luce: {type: 'real', lower: 0, upper: 100},\n  };\n\n  const logPost = (state, data) => {\n    let lp = 0;\n\n    // Priors\n    const kMean = 2;\n    const kShape = 3;\n    lp += BayesDistributions.gamma(\n      state.k,\n      kShape,\n      kShape / kMean,\n    );\n    // lp += BayesDistributions.unif(state.k, 0, 100);\n\n    const luceMean = 2;\n    const luceShape = 3;\n    lp += BayesDistributions.gamma(\n      state.luce,\n      luceShape,\n      luceShape / luceMean,\n    );\n    // lp += BayesDistributions.unif(state.luce, 0, 100);\n\n    // Likelihood\n    data.forEach((choice) => {\n      // Values\n      const vs = HTDMath.adk2v(choice.as, choice.ds, state.k);\n      const vl = HTDMath.adk2v(choice.al, choice.dl, state.k);\n\n      // Choice of sooner or later is sampled from a Bernoulli distribution\n      // Luce choice rule is used to compute probability of waiting! (0 = sooner, 1 = later)\n      const binval = 1 / (1 + Math.exp(state.luce * (vs - vl)));\n\n      // Actual response\n      const response = (choice.response === 'first') ? 0 : 1;\n\n      lp += BayesDistributions.bern(response, binval);\n    });\n\n    return lp;\n  };\n\n  // Initializing the sampler\n  const sampler = new BayesMcmc.AmwgSampler(params, logPost, event.data);\n  // Burning some samples to the MCMC gods and sampling 5000 draws\n  sampler.burn(1000);\n  const samples = sampler.sample(5000);\n\n  // Extract summary stats\n  const results = {\n    k: d3.median(samples.k),\n    luce: d3.median(samples.luce),\n  };\n\n  self.postMessage({results: results, samples: samples});\n};\n"],"names":["root","factory","module","exports","ld","this","lgamma","x","j","cof","ser","xx","y","tmp","log","lfactorial","n","NaN","lchoose","k","lbeta","a","b","Math","exp","abs","pow","sqrt","pi","PI","beta","shape1","shape2","Infinity","cauchy","location","scale","norm","mean","sd","bivarnorm","corr","z","normalizing_factor","bivar_log_dens","laplace","dexp","gamma","shape","rate","invgamma","lnorm","meanlog","sdlog","pareto","t","df","weibull","tmp1","tmp2","logis","e","f","dirichlet","alpha","sum_alpha","sum_lgamma_alpha","sum_alpha_sub_1_log_x","length","i","unif","min","max","bern","prob","cat","probs","binom","size","nbinom","hyper","m","pois","lambda","mcmc","runif","random","runif_discrete","floor","rnorm","u","v","q","deep_clone","src","mixin","dest","source","copyFunc","name","s","empty","Object","prototype","toString","call","nodeType","cloneNode","Date","getTime","RegExp","r","l","Array","push","constructor","clone_param_draw","isArray","x_copy","slice","is_number","object","Number","create_array","dim","init","arr","array_dim","concat","array_equal","a1","a2","nested_array_apply","fun","result","shuffle_array","array","temp","nested_array_random_apply","len","array_is","array_i","get_option","option_name","options","defaul_value","hasOwnProperty","undefined","get_multidim_option","value","param_init_fixed","type","lower","upper","round","complete_params","params_to_complete","param_init","params","param_name","param","Stepper","state","log_post","step","start_adaptation","stop_adaptation","info","OnedimMetropolisStepper","generate_proposal","param_names","keys","prop_log_scale","batch_size","max_adaptation","initial_adaptation","target_accept_rate","is_adapting","acceptance_count","batch_count","iterations_since_adaption","create","param_state","param_proposal","curr_log_dens","prop_log_dens","accept_prob","log_sd_adjustment","normal_proposal","RealMetropolisStepper","discrete_normal_proposal","IntMetropolisStepper","MultidimComponentMetropolisStepper","SubStepper","create_substeppers","substate","substeppers","suboptions","subparam","substepper","MultiRealComponentMetropolisStepper","MultiIntComponentMetropolisStepper","BinaryStepper","zero_log_dens","one_log_dens","max_log_dens","zero_prob","BinaryComponentStepper","subparams","AmwgStepper","SelectStepper","param_object_wrap","param_options","Sampler","data","param_init_fun","thinning_interval","params_to_monitor","thin","monitor","steppers","create_stepper_ensamble","sample","n_iterations","monitored_params","curr_sample","burn","AmwgSampler","ascending","numbers","values","valueof","compareDefined","compare","ascendingDefined","TypeError","quickselect","left","right","newLeft","newRight","swap","quantile","p","Float64Array","from","isNaN","i0","value0","subarray","value1","median","noop","dispatch","arguments","_","test","Error","Dispatch","parseTypenames","typenames","types","trim","split","map","indexOf","on","typename","callback","T","get","set","copy","that","args","apply","c","xhtml","svg","xlink","xml","xmlns","prefix","namespaces","space","local","creatorInherit","document","ownerDocument","uri","namespaceURI","documentElement","createElement","createElementNS","creatorFixed","fullname","namespace","none","selector","querySelector","select","groups","_groups","subgroups","group","subgroup","node","subnode","__data__","Selection","_parents","querySelectorAll","arrayAll","selectorAll","parents","matches","childMatcher","find","childFind","match","children","childFirst","firstElementChild","filter","childrenFilter","selectAll","matcher","update","_enter","sparse","EnterNode","parent","datum","_next","_parent","appendChild","child","insertBefore","next","bindIndex","enter","exit","groupLength","dataLength","bindKey","key","nodeByKeyValue","Map","keyValues","keyValue","has","delete","bind","constant","arraylike","enterGroup","updateGroup","exitGroup","i1","previous","_exit","onenter","onupdate","onexit","selection","append","remove","merge","order","context","groups0","groups1","m0","m1","merges","group0","group1","compareDocumentPosition","parentNode","compareNode","sortgroups","sortgroup","sort","attrRemove","removeAttribute","attrRemoveNS","removeAttributeNS","attrConstant","setAttribute","attrConstantNS","setAttributeNS","attrFunction","attrFunctionNS","getAttributeNS","getAttribute","each","defaultView","styleRemove","style","removeProperty","styleConstant","priority","setProperty","styleFunction","styleValue","getPropertyValue","getComputedStyle","propertyRemove","propertyConstant","propertyFunction","classArray","string","classList","ClassList","_node","_names","add","join","splice","contains","classedAdd","names","list","classedRemove","classedTrue","classedFalse","classedFunction","textRemove","textContent","textConstant","textFunction","htmlRemove","innerHTML","htmlConstant","htmlFunction","raise","nextSibling","previousSibling","firstChild","creator","constantNull","before","removeChild","selection_cloneShallow","clone","selection_cloneDeep","deep","property","contextListener","listener","event","onRemove","__on","o","removeEventListener","onAdd","addEventListener","dispatchEvent","window","CustomEvent","createEvent","initEvent","bubbles","cancelable","detail","dispatchConstant","dispatchFunction","selection_selection","selection_select","selection_selectAll","selectChild","selection_selectChild","selectChildren","selection_selectChildren","selection_filter","selection_data","selection_enter","selection_exit","selection_join","selection_merge","selection_order","selection_sort","selection_call","nodes","selection_nodes","selection_node","selection_size","selection_empty","selection_each","attr","selection_attr","selection_style","selection_property","classed","selection_classed","text","selection_text","html","selection_html","selection_raise","selection_lower","selection_append","insert","selection_insert","selection_remove","selection_clone","selection_datum","selection_on","selection_dispatch","Symbol","iterator","selection_iterator","extend","definition","Color","darker","brighter","reI","reN","reP","reHex","reRgbInteger","reRgbPercent","reRgbaInteger","reRgbaPercent","reHslPercent","reHslaPercent","named","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","define","color","channels","assign","displayable","rgb","hex","color_formatHex","formatHex","formatHex8","color_formatHex8","formatHsl","color_formatHsl","formatRgb","color_formatRgb","hslConvert","format","toLowerCase","exec","parseInt","rgbn","Rgb","rgba","hsla","g","rgbConvert","opacity","clamp","clampi","clampa","rgb_formatHex","rgb_formatHex8","rgb_formatRgb","h","Hsl","hsl","m2","hsl2rgb","clamph","clampt","linear","d","exponential","nogamma","rgbGamma","start","end","colorRgb","reA","reB","zero","one","bi","lastIndex","am","bm","bs","index","number","degrees","identity","translateX","translateY","rotate","skewX","scaleX","scaleY","atan2","atan","svgNode","parseCss","DOMMatrix","WebKitCSSMatrix","isIdentity","decompose","parseSvg","transform","baseVal","consolidate","matrix","interpolateTransform","parse","pxComma","pxParen","degParen","pop","translate","xa","ya","xb","yb","interpolateTransformCss","interpolateTransformSvg","frame","timeout","interval","pokeDelay","taskHead","taskTail","clockLast","clockNow","clockSkew","clock","performance","now","setFrame","requestAnimationFrame","setTimeout","clearNow","Timer","_call","_time","timer","restart","delay","time","sleep","stop","timerFlush","wake","nap","poke","t0","t1","t2","clearTimeout","clearInterval","setInterval","elapsed","emptyOn","emptyTween","CREATED","SCHEDULED","STARTING","STARTED","RUNNING","ENDING","ENDED","id","timing","schedules","__transition","tween","duration","ease","schedule","self","tick","active","interrupt","tweenRemove","tween0","tween1","tweenFunction","_id","tweenValue","transition","interpolateNumber","interpolateRgb","interpolateString","interpolate","string00","string1","interpolate0","string0","string10","attrTween","attrInterpolate","attrInterpolateNS","attrTweenNS","_value","delayFunction","delayConstant","durationFunction","durationConstant","easeConstant","easeVarying","Transition","_name","every","onFunction","on0","on1","sit","removeFunction","inherit","styleNull","styleMaybeRemove","listener0","styleTween","styleInterpolate","textInterpolate","textTween","id0","id1","newId","Promise","resolve","reject","cancel","selection_prototype","transition_select","transition_selectAll","transition_filter","transition_merge","transition_selection","transition_transition","transition_on","transition_attr","transition_attrTween","transition_style","transition_styleTween","transition_text","transition_textTween","transition_remove","transition_tween","transition_delay","transition_duration","transition_ease","transition_easeVarying","transition_end","cubicInOut","defaultTiming","easeCubicInOut","selection_interrupt","selection_transition","Transform","point","applyX","applyY","invert","invertX","invertY","rescaleX","domain","range","rescaleY","HTDMath","DEFAULT","MIN","MAX","STEP","JUMP","adk2v","adv2k","onmessage","luce","logPost","lp","kMean","kShape","BayesDistributions","luceMean","luceShape","forEach","choice","vs","as","ds","vl","al","dl","binval","response","sampler","BayesMcmc","samples","results","d3","postMessage"],"mappings":"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","x_google_ignoreList":[0,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]}');
22778
22858
  /* eslint-enable */
22779
22859
 
22780
22860
  /*