@decidables/discountable-elements 0.2.0 → 0.3.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.
@@ -3,21 +3,21 @@
3
3
  * Copyright 2019 Google LLC
4
4
  * SPDX-License-Identifier: BSD-3-Clause
5
5
  */
6
- const t$2 = window,
7
- e$4 = t$2.ShadowRoot && (void 0 === t$2.ShadyCSS || t$2.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
8
- s$5 = Symbol(),
9
- n$5 = new WeakMap();
10
- let o$4 = class o {
11
- constructor(t, e, n) {
12
- if (this._$cssResult$ = !0, n !== s$5) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
6
+ const t$2 = globalThis,
7
+ e$3 = t$2.ShadowRoot && (void 0 === t$2.ShadyCSS || t$2.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
8
+ s$4 = Symbol(),
9
+ o$5 = new WeakMap();
10
+ let n$4 = class n {
11
+ constructor(t, e, o) {
12
+ if (this._$cssResult$ = !0, o !== s$4) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
13
13
  this.cssText = t, this.t = e;
14
14
  }
15
15
  get styleSheet() {
16
16
  let t = this.o;
17
17
  const s = this.t;
18
- if (e$4 && void 0 === t) {
18
+ if (e$3 && void 0 === t) {
19
19
  const e = void 0 !== s && 1 === s.length;
20
- e && (t = n$5.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && n$5.set(s, t));
20
+ e && (t = o$5.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$5.set(s, t));
21
21
  }
22
22
  return t;
23
23
  }
@@ -25,26 +25,26 @@ let o$4 = class o {
25
25
  return this.cssText;
26
26
  }
27
27
  };
28
- const r$4 = t => new o$4("string" == typeof t ? t : t + "", void 0, s$5),
29
- i$3 = (t, ...e) => {
30
- const n = 1 === t.length ? t[0] : e.reduce((e, s, n) => e + (t => {
28
+ const r$5 = t => new n$4("string" == typeof t ? t : t + "", void 0, s$4),
29
+ i$4 = (t, ...e) => {
30
+ const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
31
31
  if (!0 === t._$cssResult$) return t.cssText;
32
32
  if ("number" == typeof t) return t;
33
33
  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.");
34
- })(s) + t[n + 1], t[0]);
35
- return new o$4(n, t, s$5);
34
+ })(s) + t[o + 1], t[0]);
35
+ return new n$4(o, t, s$4);
36
36
  },
37
- S$1 = (s, n) => {
38
- e$4 ? s.adoptedStyleSheets = n.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet) : n.forEach(e => {
39
- const n = document.createElement("style"),
40
- o = t$2.litNonce;
41
- void 0 !== o && n.setAttribute("nonce", o), n.textContent = e.cssText, s.appendChild(n);
42
- });
37
+ S$1 = (s, o) => {
38
+ if (e$3) s.adoptedStyleSheets = o.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet);else for (const e of o) {
39
+ const o = document.createElement("style"),
40
+ n = t$2.litNonce;
41
+ void 0 !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
42
+ }
43
43
  },
44
- c$5 = e$4 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
44
+ c$6 = e$3 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
45
45
  let e = "";
46
46
  for (const s of t.cssRules) e += s.cssText;
47
- return r$4(e);
47
+ return r$5(e);
48
48
  })(t) : t;
49
49
 
50
50
  /**
@@ -52,16 +52,24 @@ const r$4 = t => new o$4("string" == typeof t ? t : t + "", void 0, s$5),
52
52
  * Copyright 2017 Google LLC
53
53
  * SPDX-License-Identifier: BSD-3-Clause
54
54
  */
55
- var s$4;
56
- const e$3 = window,
57
- r$3 = e$3.trustedTypes,
58
- h$3 = r$3 ? r$3.emptyScript : "",
59
- o$3 = e$3.reactiveElementPolyfillSupport,
60
- n$4 = {
61
- toAttribute(t, i) {
62
- switch (i) {
55
+ const {
56
+ is: i$3,
57
+ defineProperty: e$2,
58
+ getOwnPropertyDescriptor: r$4,
59
+ getOwnPropertyNames: h$2,
60
+ getOwnPropertySymbols: o$4,
61
+ getPrototypeOf: n$3
62
+ } = Object,
63
+ a$3 = globalThis,
64
+ c$5 = a$3.trustedTypes,
65
+ l$1 = c$5 ? c$5.emptyScript : "",
66
+ p$1 = a$3.reactiveElementPolyfillSupport,
67
+ d$1 = (t, s) => t,
68
+ u$1 = {
69
+ toAttribute(t, s) {
70
+ switch (s) {
63
71
  case Boolean:
64
- t = t ? h$3 : null;
72
+ t = t ? l$1 : null;
65
73
  break;
66
74
  case Object:
67
75
  case Array:
@@ -69,165 +77,177 @@ const e$3 = window,
69
77
  }
70
78
  return t;
71
79
  },
72
- fromAttribute(t, i) {
73
- let s = t;
74
- switch (i) {
80
+ fromAttribute(t, s) {
81
+ let i = t;
82
+ switch (s) {
75
83
  case Boolean:
76
- s = null !== t;
84
+ i = null !== t;
77
85
  break;
78
86
  case Number:
79
- s = null === t ? null : Number(t);
87
+ i = null === t ? null : Number(t);
80
88
  break;
81
89
  case Object:
82
90
  case Array:
83
91
  try {
84
- s = JSON.parse(t);
92
+ i = JSON.parse(t);
85
93
  } catch (t) {
86
- s = null;
94
+ i = null;
87
95
  }
88
96
  }
89
- return s;
97
+ return i;
90
98
  }
91
99
  },
92
- a$3 = (t, i) => i !== t && (i == i || t == t),
93
- l$4 = {
100
+ f$3 = (t, s) => !i$3(t, s),
101
+ y$2 = {
94
102
  attribute: !0,
95
103
  type: String,
96
- converter: n$4,
104
+ converter: u$1,
97
105
  reflect: !1,
98
- hasChanged: a$3
99
- },
100
- d$1 = "finalized";
101
- let u$1 = class u extends HTMLElement {
102
- constructor() {
103
- super(), this._$Ei = new Map(), this.isUpdatePending = !1, this.hasUpdated = !1, this._$El = null, this._$Eu();
104
- }
106
+ hasChanged: f$3
107
+ };
108
+ Symbol.metadata ??= Symbol("metadata"), a$3.litPropertyMetadata ??= new WeakMap();
109
+ let b$2 = class b extends HTMLElement {
105
110
  static addInitializer(t) {
106
- var i;
107
- this.finalize(), (null !== (i = this.h) && void 0 !== i ? i : this.h = []).push(t);
111
+ this._$Ei(), (this.l ??= []).push(t);
108
112
  }
109
113
  static get observedAttributes() {
110
- this.finalize();
111
- const t = [];
112
- return this.elementProperties.forEach((i, s) => {
113
- const e = this._$Ep(s, i);
114
- void 0 !== e && (this._$Ev.set(e, s), t.push(e));
115
- }), t;
114
+ return this.finalize(), this._$Eh && [...this._$Eh.keys()];
116
115
  }
117
- static createProperty(t, i = l$4) {
118
- if (i.state && (i.attribute = !1), this.finalize(), this.elementProperties.set(t, i), !i.noAccessor && !this.prototype.hasOwnProperty(t)) {
119
- const s = "symbol" == typeof t ? Symbol() : "__" + t,
120
- e = this.getPropertyDescriptor(t, s, i);
121
- void 0 !== e && Object.defineProperty(this.prototype, t, e);
116
+ static createProperty(t, s = y$2) {
117
+ if (s.state && (s.attribute = !1), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
118
+ const i = Symbol(),
119
+ r = this.getPropertyDescriptor(t, i, s);
120
+ void 0 !== r && e$2(this.prototype, t, r);
122
121
  }
123
122
  }
124
- static getPropertyDescriptor(t, i, s) {
123
+ static getPropertyDescriptor(t, s, i) {
124
+ const {
125
+ get: e,
126
+ set: h
127
+ } = r$4(this.prototype, t) ?? {
128
+ get() {
129
+ return this[s];
130
+ },
131
+ set(t) {
132
+ this[s] = t;
133
+ }
134
+ };
125
135
  return {
126
136
  get() {
127
- return this[i];
137
+ return e?.call(this);
128
138
  },
129
- set(e) {
130
- const r = this[t];
131
- this[i] = e, this.requestUpdate(t, r, s);
139
+ set(s) {
140
+ const r = e?.call(this);
141
+ h.call(this, s), this.requestUpdate(t, r, i);
132
142
  },
133
143
  configurable: !0,
134
144
  enumerable: !0
135
145
  };
136
146
  }
137
147
  static getPropertyOptions(t) {
138
- return this.elementProperties.get(t) || l$4;
148
+ return this.elementProperties.get(t) ?? y$2;
149
+ }
150
+ static _$Ei() {
151
+ if (this.hasOwnProperty(d$1("elementProperties"))) return;
152
+ const t = n$3(this);
153
+ t.finalize(), void 0 !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
139
154
  }
140
155
  static finalize() {
141
- if (this.hasOwnProperty(d$1)) return !1;
142
- this[d$1] = !0;
143
- const t = Object.getPrototypeOf(this);
144
- if (t.finalize(), void 0 !== t.h && (this.h = [...t.h]), this.elementProperties = new Map(t.elementProperties), this._$Ev = new Map(), this.hasOwnProperty("properties")) {
156
+ if (this.hasOwnProperty(d$1("finalized"))) return;
157
+ if (this.finalized = !0, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
145
158
  const t = this.properties,
146
- i = [...Object.getOwnPropertyNames(t), ...Object.getOwnPropertySymbols(t)];
147
- for (const s of i) this.createProperty(s, t[s]);
159
+ s = [...h$2(t), ...o$4(t)];
160
+ for (const i of s) this.createProperty(i, t[i]);
148
161
  }
149
- return this.elementStyles = this.finalizeStyles(this.styles), !0;
162
+ const t = this[Symbol.metadata];
163
+ if (null !== t) {
164
+ const s = litPropertyMetadata.get(t);
165
+ if (void 0 !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
166
+ }
167
+ this._$Eh = new Map();
168
+ for (const [t, s] of this.elementProperties) {
169
+ const i = this._$Eu(t, s);
170
+ void 0 !== i && this._$Eh.set(i, t);
171
+ }
172
+ this.elementStyles = this.finalizeStyles(this.styles);
150
173
  }
151
- static finalizeStyles(i) {
152
- const s = [];
153
- if (Array.isArray(i)) {
154
- const e = new Set(i.flat(1 / 0).reverse());
155
- for (const i of e) s.unshift(c$5(i));
156
- } else void 0 !== i && s.push(c$5(i));
157
- return s;
174
+ static finalizeStyles(s) {
175
+ const i = [];
176
+ if (Array.isArray(s)) {
177
+ const e = new Set(s.flat(1 / 0).reverse());
178
+ for (const s of e) i.unshift(c$6(s));
179
+ } else void 0 !== s && i.push(c$6(s));
180
+ return i;
158
181
  }
159
- static _$Ep(t, i) {
160
- const s = i.attribute;
161
- return !1 === s ? void 0 : "string" == typeof s ? s : "string" == typeof t ? t.toLowerCase() : void 0;
182
+ static _$Eu(t, s) {
183
+ const i = s.attribute;
184
+ return !1 === i ? void 0 : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : void 0;
162
185
  }
163
- _$Eu() {
164
- var t;
165
- this._$E_ = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$Eg(), this.requestUpdate(), null === (t = this.constructor.h) || void 0 === t || t.forEach(t => t(this));
186
+ constructor() {
187
+ super(), this._$Ep = void 0, this.isUpdatePending = !1, this.hasUpdated = !1, this._$Em = null, this._$Ev();
188
+ }
189
+ _$Ev() {
190
+ this._$Eg = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$ES(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
166
191
  }
167
192
  addController(t) {
168
- var i, s;
169
- (null !== (i = this._$ES) && void 0 !== i ? i : this._$ES = []).push(t), void 0 !== this.renderRoot && this.isConnected && (null === (s = t.hostConnected) || void 0 === s || s.call(t));
193
+ (this._$E_ ??= new Set()).add(t), void 0 !== this.renderRoot && this.isConnected && t.hostConnected?.();
170
194
  }
171
195
  removeController(t) {
172
- var i;
173
- null === (i = this._$ES) || void 0 === i || i.splice(this._$ES.indexOf(t) >>> 0, 1);
196
+ this._$E_?.delete(t);
174
197
  }
175
- _$Eg() {
176
- this.constructor.elementProperties.forEach((t, i) => {
177
- this.hasOwnProperty(i) && (this._$Ei.set(i, this[i]), delete this[i]);
178
- });
198
+ _$ES() {
199
+ const t = new Map(),
200
+ s = this.constructor.elementProperties;
201
+ for (const i of s.keys()) this.hasOwnProperty(i) && (t.set(i, this[i]), delete this[i]);
202
+ t.size > 0 && (this._$Ep = t);
179
203
  }
180
204
  createRenderRoot() {
181
- var t;
182
- const s = null !== (t = this.shadowRoot) && void 0 !== t ? t : this.attachShadow(this.constructor.shadowRootOptions);
183
- return S$1(s, this.constructor.elementStyles), s;
205
+ const t = this.shadowRoot ?? this.attachShadow(this.constructor.shadowRootOptions);
206
+ return S$1(t, this.constructor.elementStyles), t;
184
207
  }
185
208
  connectedCallback() {
186
- var t;
187
- void 0 === this.renderRoot && (this.renderRoot = this.createRenderRoot()), this.enableUpdating(!0), null === (t = this._$ES) || void 0 === t || t.forEach(t => {
188
- var i;
189
- return null === (i = t.hostConnected) || void 0 === i ? void 0 : i.call(t);
190
- });
209
+ this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(!0), this._$E_?.forEach(t => t.hostConnected?.());
191
210
  }
192
211
  enableUpdating(t) {}
193
212
  disconnectedCallback() {
194
- var t;
195
- null === (t = this._$ES) || void 0 === t || t.forEach(t => {
196
- var i;
197
- return null === (i = t.hostDisconnected) || void 0 === i ? void 0 : i.call(t);
198
- });
213
+ this._$E_?.forEach(t => t.hostDisconnected?.());
199
214
  }
200
- attributeChangedCallback(t, i, s) {
201
- this._$AK(t, s);
215
+ attributeChangedCallback(t, s, i) {
216
+ this._$AK(t, i);
202
217
  }
203
- _$EO(t, i, s = l$4) {
204
- var e;
205
- const r = this.constructor._$Ep(t, s);
206
- if (void 0 !== r && !0 === s.reflect) {
207
- const h = (void 0 !== (null === (e = s.converter) || void 0 === e ? void 0 : e.toAttribute) ? s.converter : n$4).toAttribute(i, s.type);
208
- this._$El = t, null == h ? this.removeAttribute(r) : this.setAttribute(r, h), this._$El = null;
218
+ _$EO(t, s) {
219
+ const i = this.constructor.elementProperties.get(t),
220
+ e = this.constructor._$Eu(t, i);
221
+ if (void 0 !== e && !0 === i.reflect) {
222
+ const r = (void 0 !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
223
+ this._$Em = t, null == r ? this.removeAttribute(e) : this.setAttribute(e, r), this._$Em = null;
209
224
  }
210
225
  }
211
- _$AK(t, i) {
212
- var s;
213
- const e = this.constructor,
214
- r = e._$Ev.get(t);
215
- if (void 0 !== r && this._$El !== r) {
216
- const t = e.getPropertyOptions(r),
217
- h = "function" == typeof t.converter ? {
226
+ _$AK(t, s) {
227
+ const i = this.constructor,
228
+ e = i._$Eh.get(t);
229
+ if (void 0 !== e && this._$Em !== e) {
230
+ const t = i.getPropertyOptions(e),
231
+ r = "function" == typeof t.converter ? {
218
232
  fromAttribute: t.converter
219
- } : void 0 !== (null === (s = t.converter) || void 0 === s ? void 0 : s.fromAttribute) ? t.converter : n$4;
220
- this._$El = r, this[r] = h.fromAttribute(i, t.type), this._$El = null;
233
+ } : void 0 !== t.converter?.fromAttribute ? t.converter : u$1;
234
+ this._$Em = e, this[e] = r.fromAttribute(s, t.type), this._$Em = null;
221
235
  }
222
236
  }
223
- requestUpdate(t, i, s) {
224
- let e = !0;
225
- void 0 !== t && (((s = s || this.constructor.getPropertyOptions(t)).hasChanged || a$3)(this[t], i) ? (this._$AL.has(t) || this._$AL.set(t, i), !0 === s.reflect && this._$El !== t && (void 0 === this._$EC && (this._$EC = new Map()), this._$EC.set(t, s))) : e = !1), !this.isUpdatePending && e && (this._$E_ = this._$Ej());
237
+ requestUpdate(t, s, i, e = !1, r) {
238
+ if (void 0 !== t) {
239
+ if (i ??= this.constructor.getPropertyOptions(t), !(i.hasChanged ?? f$3)(e ? r : this[t], s)) return;
240
+ this.C(t, s, i);
241
+ }
242
+ !1 === this.isUpdatePending && (this._$Eg = this._$EP());
243
+ }
244
+ C(t, s, i) {
245
+ this._$AL.has(t) || this._$AL.set(t, s), !0 === i.reflect && this._$Em !== t && (this._$Ej ??= new Set()).add(t);
226
246
  }
227
- async _$Ej() {
247
+ async _$EP() {
228
248
  this.isUpdatePending = !0;
229
249
  try {
230
- await this._$E_;
250
+ await this._$Eg;
231
251
  } catch (t) {
232
252
  Promise.reject(t);
233
253
  }
@@ -238,192 +258,182 @@ let u$1 = class u extends HTMLElement {
238
258
  return this.performUpdate();
239
259
  }
240
260
  performUpdate() {
241
- var t;
242
261
  if (!this.isUpdatePending) return;
243
- this.hasUpdated, this._$Ei && (this._$Ei.forEach((t, i) => this[i] = t), this._$Ei = void 0);
244
- let i = !1;
262
+ if (!this.hasUpdated) {
263
+ if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
264
+ for (const [t, s] of this._$Ep) this[t] = s;
265
+ this._$Ep = void 0;
266
+ }
267
+ const t = this.constructor.elementProperties;
268
+ if (t.size > 0) for (const [s, i] of t) !0 !== i.wrapped || this._$AL.has(s) || void 0 === this[s] || this.C(s, this[s], i);
269
+ }
270
+ let t = !1;
245
271
  const s = this._$AL;
246
272
  try {
247
- i = this.shouldUpdate(s), i ? (this.willUpdate(s), null === (t = this._$ES) || void 0 === t || t.forEach(t => {
248
- var i;
249
- return null === (i = t.hostUpdate) || void 0 === i ? void 0 : i.call(t);
250
- }), this.update(s)) : this._$Ek();
251
- } catch (t) {
252
- throw i = !1, this._$Ek(), t;
273
+ t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$E_?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$ET();
274
+ } catch (s) {
275
+ throw t = !1, this._$ET(), s;
253
276
  }
254
- i && this._$AE(s);
277
+ t && this._$AE(s);
255
278
  }
256
279
  willUpdate(t) {}
257
280
  _$AE(t) {
258
- var i;
259
- null === (i = this._$ES) || void 0 === i || i.forEach(t => {
260
- var i;
261
- return null === (i = t.hostUpdated) || void 0 === i ? void 0 : i.call(t);
262
- }), this.hasUpdated || (this.hasUpdated = !0, this.firstUpdated(t)), this.updated(t);
281
+ this._$E_?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = !0, this.firstUpdated(t)), this.updated(t);
263
282
  }
264
- _$Ek() {
283
+ _$ET() {
265
284
  this._$AL = new Map(), this.isUpdatePending = !1;
266
285
  }
267
286
  get updateComplete() {
268
287
  return this.getUpdateComplete();
269
288
  }
270
289
  getUpdateComplete() {
271
- return this._$E_;
290
+ return this._$Eg;
272
291
  }
273
292
  shouldUpdate(t) {
274
293
  return !0;
275
294
  }
276
295
  update(t) {
277
- void 0 !== this._$EC && (this._$EC.forEach((t, i) => this._$EO(i, this[i], t)), this._$EC = void 0), this._$Ek();
296
+ this._$Ej &&= this._$Ej.forEach(t => this._$EO(t, this[t])), this._$ET();
278
297
  }
279
298
  updated(t) {}
280
299
  firstUpdated(t) {}
281
300
  };
282
- u$1[d$1] = !0, u$1.elementProperties = new Map(), u$1.elementStyles = [], u$1.shadowRootOptions = {
301
+ b$2.elementStyles = [], b$2.shadowRootOptions = {
283
302
  mode: "open"
284
- }, null == o$3 || o$3({
285
- ReactiveElement: u$1
286
- }), (null !== (s$4 = e$3.reactiveElementVersions) && void 0 !== s$4 ? s$4 : e$3.reactiveElementVersions = []).push("1.6.3");
303
+ }, b$2[d$1("elementProperties")] = new Map(), b$2[d$1("finalized")] = new Map(), p$1?.({
304
+ ReactiveElement: b$2
305
+ }), (a$3.reactiveElementVersions ??= []).push("2.0.2");
287
306
 
288
307
  /**
289
308
  * @license
290
309
  * Copyright 2017 Google LLC
291
310
  * SPDX-License-Identifier: BSD-3-Clause
292
311
  */
293
- var t$1;
294
- const i$2 = window,
295
- s$3 = i$2.trustedTypes,
296
- e$2 = s$3 ? s$3.createPolicy("lit-html", {
312
+ const t$1 = globalThis,
313
+ i$2 = t$1.trustedTypes,
314
+ s$3 = i$2 ? i$2.createPolicy("lit-html", {
297
315
  createHTML: t => t
298
316
  }) : void 0,
299
- o$2 = "$lit$",
300
- n$3 = `lit$${(Math.random() + "").slice(9)}$`,
301
- l$3 = "?" + n$3,
302
- h$2 = `<${l$3}>`,
303
- r$2 = document,
304
- u = () => r$2.createComment(""),
305
- d = t => null === t || "object" != typeof t && "function" != typeof t,
306
- c$4 = Array.isArray,
307
- v = t => c$4(t) || "function" == typeof (null == t ? void 0 : t[Symbol.iterator]),
308
- a$2 = "[ \t\n\f\r]",
309
- f = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,
310
- _ = /-->/g,
311
- m = />/g,
312
- p$1 = RegExp(`>|${a$2}(?:([^\\s"'>=/]+)(${a$2}*=${a$2}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`, "g"),
313
- g$1 = /'/g,
314
- $ = /"/g,
315
- y$1 = /^(?:script|style|textarea|title)$/i,
316
- w$1 = t => (i, ...s) => ({
317
+ e$1 = "$lit$",
318
+ h$1 = `lit$${(Math.random() + "").slice(9)}$`,
319
+ o$3 = "?" + h$1,
320
+ n$2 = `<${o$3}>`,
321
+ r$3 = document,
322
+ l = () => r$3.createComment(""),
323
+ c$4 = t => null === t || "object" != typeof t && "function" != typeof t,
324
+ a$2 = Array.isArray,
325
+ u = t => a$2(t) || "function" == typeof t?.[Symbol.iterator],
326
+ d = "[ \t\n\f\r]",
327
+ f$2 = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,
328
+ v$1 = /-->/g,
329
+ _ = />/g,
330
+ m = RegExp(`>|${d}(?:([^\\s"'>=/]+)(${d}*=${d}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`, "g"),
331
+ p = /'/g,
332
+ g$1 = /"/g,
333
+ $ = /^(?:script|style|textarea|title)$/i,
334
+ y$1 = t => (i, ...s) => ({
317
335
  _$litType$: t,
318
336
  strings: i,
319
337
  values: s
320
338
  }),
321
- x$2 = w$1(1),
322
- b$1 = w$1(2),
323
- T = Symbol.for("lit-noChange"),
324
- A$2 = Symbol.for("lit-nothing"),
325
- E$1 = new WeakMap(),
326
- C$1 = r$2.createTreeWalker(r$2, 129, null, !1);
327
- function P(t, i) {
339
+ x$2 = y$1(1),
340
+ b$1 = y$1(2),
341
+ w$1 = Symbol.for("lit-noChange"),
342
+ T = Symbol.for("lit-nothing"),
343
+ A$2 = new WeakMap(),
344
+ E$1 = r$3.createTreeWalker(r$3, 129);
345
+ function C$1(t, i) {
328
346
  if (!Array.isArray(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
329
- return void 0 !== e$2 ? e$2.createHTML(i) : i;
347
+ return void 0 !== s$3 ? s$3.createHTML(i) : i;
330
348
  }
331
- const V = (t, i) => {
349
+ const P = (t, i) => {
332
350
  const s = t.length - 1,
333
- e = [];
334
- let l,
335
- r = 2 === i ? "<svg>" : "",
336
- u = f;
351
+ o = [];
352
+ let r,
353
+ l = 2 === i ? "<svg>" : "",
354
+ c = f$2;
337
355
  for (let i = 0; i < s; i++) {
338
356
  const s = t[i];
339
- let d,
340
- c,
341
- v = -1,
342
- a = 0;
343
- for (; a < s.length && (u.lastIndex = a, c = u.exec(s), null !== c);) a = u.lastIndex, u === f ? "!--" === c[1] ? u = _ : void 0 !== c[1] ? u = m : void 0 !== c[2] ? (y$1.test(c[2]) && (l = RegExp("</" + c[2], "g")), u = p$1) : void 0 !== c[3] && (u = p$1) : u === p$1 ? ">" === c[0] ? (u = null != l ? l : f, v = -1) : void 0 === c[1] ? v = -2 : (v = u.lastIndex - c[2].length, d = c[1], u = void 0 === c[3] ? p$1 : '"' === c[3] ? $ : g$1) : u === $ || u === g$1 ? u = p$1 : u === _ || u === m ? u = f : (u = p$1, l = void 0);
344
- const w = u === p$1 && t[i + 1].startsWith("/>") ? " " : "";
345
- r += u === f ? s + h$2 : v >= 0 ? (e.push(d), s.slice(0, v) + o$2 + s.slice(v) + n$3 + w) : s + n$3 + (-2 === v ? (e.push(void 0), i) : w);
346
- }
347
- return [P(t, r + (t[s] || "<?>") + (2 === i ? "</svg>" : "")), e];
357
+ let a,
358
+ u,
359
+ d = -1,
360
+ y = 0;
361
+ 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);
362
+ const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
363
+ 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);
364
+ }
365
+ return [C$1(t, l + (t[s] || "<?>") + (2 === i ? "</svg>" : "")), o];
348
366
  };
349
- let N$1 = class N {
367
+ class V {
350
368
  constructor({
351
369
  strings: t,
352
- _$litType$: i
353
- }, e) {
354
- let h;
370
+ _$litType$: s
371
+ }, n) {
372
+ let r;
355
373
  this.parts = [];
356
- let r = 0,
357
- d = 0;
358
- const c = t.length - 1,
359
- v = this.parts,
360
- [a, f] = V(t, i);
361
- if (this.el = N.createElement(a, e), C$1.currentNode = this.el.content, 2 === i) {
362
- const t = this.el.content,
363
- i = t.firstChild;
364
- i.remove(), t.append(...i.childNodes);
365
- }
366
- for (; null !== (h = C$1.nextNode()) && v.length < c;) {
367
- if (1 === h.nodeType) {
368
- if (h.hasAttributes()) {
369
- const t = [];
370
- for (const i of h.getAttributeNames()) if (i.endsWith(o$2) || i.startsWith(n$3)) {
371
- const s = f[d++];
372
- if (t.push(i), void 0 !== s) {
373
- const t = h.getAttribute(s.toLowerCase() + o$2).split(n$3),
374
- i = /([.?@])?(.*)/.exec(s);
375
- v.push({
376
- type: 1,
377
- index: r,
378
- name: i[2],
379
- strings: t,
380
- ctor: "." === i[1] ? H : "?" === i[1] ? L : "@" === i[1] ? z : k$1
381
- });
382
- } else v.push({
383
- type: 6,
384
- index: r
385
- });
386
- }
387
- for (const i of t) h.removeAttribute(i);
388
- }
389
- if (y$1.test(h.tagName)) {
390
- const t = h.textContent.split(n$3),
391
- i = t.length - 1;
392
- if (i > 0) {
393
- h.textContent = s$3 ? s$3.emptyScript : "";
394
- for (let s = 0; s < i; s++) h.append(t[s], u()), C$1.nextNode(), v.push({
374
+ let c = 0,
375
+ a = 0;
376
+ const u = t.length - 1,
377
+ d = this.parts,
378
+ [f, v] = P(t, s);
379
+ if (this.el = V.createElement(f, n), E$1.currentNode = this.el.content, 2 === s) {
380
+ const t = this.el.content.firstChild;
381
+ t.replaceWith(...t.childNodes);
382
+ }
383
+ for (; null !== (r = E$1.nextNode()) && d.length < u;) {
384
+ if (1 === r.nodeType) {
385
+ if (r.hasAttributes()) for (const t of r.getAttributeNames()) if (t.endsWith(e$1)) {
386
+ const i = v[a++],
387
+ s = r.getAttribute(t).split(h$1),
388
+ e = /([.?@])?(.*)/.exec(i);
389
+ d.push({
390
+ type: 1,
391
+ index: c,
392
+ name: e[2],
393
+ strings: s,
394
+ ctor: "." === e[1] ? k$1 : "?" === e[1] ? H : "@" === e[1] ? I : R
395
+ }), r.removeAttribute(t);
396
+ } else t.startsWith(h$1) && (d.push({
397
+ type: 6,
398
+ index: c
399
+ }), r.removeAttribute(t));
400
+ if ($.test(r.tagName)) {
401
+ const t = r.textContent.split(h$1),
402
+ s = t.length - 1;
403
+ if (s > 0) {
404
+ r.textContent = i$2 ? i$2.emptyScript : "";
405
+ for (let i = 0; i < s; i++) r.append(t[i], l()), E$1.nextNode(), d.push({
395
406
  type: 2,
396
- index: ++r
407
+ index: ++c
397
408
  });
398
- h.append(t[i], u());
409
+ r.append(t[s], l());
399
410
  }
400
411
  }
401
- } else if (8 === h.nodeType) if (h.data === l$3) v.push({
412
+ } else if (8 === r.nodeType) if (r.data === o$3) d.push({
402
413
  type: 2,
403
- index: r
414
+ index: c
404
415
  });else {
405
416
  let t = -1;
406
- for (; -1 !== (t = h.data.indexOf(n$3, t + 1));) v.push({
417
+ for (; -1 !== (t = r.data.indexOf(h$1, t + 1));) d.push({
407
418
  type: 7,
408
- index: r
409
- }), t += n$3.length - 1;
419
+ index: c
420
+ }), t += h$1.length - 1;
410
421
  }
411
- r++;
422
+ c++;
412
423
  }
413
424
  }
414
425
  static createElement(t, i) {
415
- const s = r$2.createElement("template");
426
+ const s = r$3.createElement("template");
416
427
  return s.innerHTML = t, s;
417
428
  }
418
- };
419
- function S(t, i, s = t, e) {
420
- var o, n, l, h;
421
- if (i === T) return i;
422
- let r = void 0 !== e ? null === (o = s._$Co) || void 0 === o ? void 0 : o[e] : s._$Cl;
423
- const u = d(i) ? void 0 : i._$litDirective$;
424
- return (null == r ? void 0 : r.constructor) !== u && (null === (n = null == r ? void 0 : r._$AO) || void 0 === n || n.call(r, !1), void 0 === u ? r = void 0 : (r = new u(t), r._$AT(t, s, e)), void 0 !== e ? (null !== (l = (h = s)._$Co) && void 0 !== l ? l : h._$Co = [])[e] = r : s._$Cl = r), void 0 !== r && (i = S(t, r._$AS(t, i.values), r, e)), i;
425
429
  }
426
- let M$1 = class M {
430
+ function N$1(t, i, s = t, e) {
431
+ if (i === w$1) return i;
432
+ let h = void 0 !== e ? s._$Co?.[e] : s._$Cl;
433
+ const o = c$4(i) ? void 0 : i._$litDirective$;
434
+ return h?.constructor !== o && (h?._$AO?.(!1), 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 = N$1(t, h._$AS(t, i.values), h, e)), i;
435
+ }
436
+ class S {
427
437
  constructor(t, i) {
428
438
  this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = i;
429
439
  }
@@ -434,46 +444,43 @@ let M$1 = class M {
434
444
  return this._$AM._$AU;
435
445
  }
436
446
  u(t) {
437
- var i;
438
447
  const {
439
448
  el: {
440
- content: s
449
+ content: i
441
450
  },
442
- parts: e
451
+ parts: s
443
452
  } = this._$AD,
444
- o = (null !== (i = null == t ? void 0 : t.creationScope) && void 0 !== i ? i : r$2).importNode(s, !0);
445
- C$1.currentNode = o;
446
- let n = C$1.nextNode(),
447
- l = 0,
448
- h = 0,
449
- u = e[0];
450
- for (; void 0 !== u;) {
451
- if (l === u.index) {
453
+ e = (t?.creationScope ?? r$3).importNode(i, !0);
454
+ E$1.currentNode = e;
455
+ let h = E$1.nextNode(),
456
+ o = 0,
457
+ n = 0,
458
+ l = s[0];
459
+ for (; void 0 !== l;) {
460
+ if (o === l.index) {
452
461
  let i;
453
- 2 === u.type ? i = new R(n, n.nextSibling, this, t) : 1 === u.type ? i = new u.ctor(n, u.name, u.strings, this, t) : 6 === u.type && (i = new Z(n, this, t)), this._$AV.push(i), u = e[++h];
462
+ 2 === l.type ? i = new M$1(h, h.nextSibling, this, t) : 1 === l.type ? i = new l.ctor(h, l.name, l.strings, this, t) : 6 === l.type && (i = new L(h, this, t)), this._$AV.push(i), l = s[++n];
454
463
  }
455
- l !== (null == u ? void 0 : u.index) && (n = C$1.nextNode(), l++);
464
+ o !== l?.index && (h = E$1.nextNode(), o++);
456
465
  }
457
- return C$1.currentNode = r$2, o;
466
+ return E$1.currentNode = r$3, e;
458
467
  }
459
- v(t) {
468
+ p(t) {
460
469
  let i = 0;
461
470
  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++;
462
471
  }
463
- };
464
- class R {
465
- constructor(t, i, s, e) {
466
- var o;
467
- this.type = 2, this._$AH = A$2, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cp = null === (o = null == e ? void 0 : e.isConnected) || void 0 === o || o;
468
- }
472
+ }
473
+ let M$1 = class M {
469
474
  get _$AU() {
470
- var t, i;
471
- return null !== (i = null === (t = this._$AM) || void 0 === t ? void 0 : t._$AU) && void 0 !== i ? i : this._$Cp;
475
+ return this._$AM?._$AU ?? this._$Cv;
476
+ }
477
+ constructor(t, i, s, e) {
478
+ this.type = 2, this._$AH = T, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? !0;
472
479
  }
473
480
  get parentNode() {
474
481
  let t = this._$AA.parentNode;
475
482
  const i = this._$AM;
476
- return void 0 !== i && 11 === (null == t ? void 0 : t.nodeType) && (t = i.parentNode), t;
483
+ return void 0 !== i && 11 === t?.nodeType && (t = i.parentNode), t;
477
484
  }
478
485
  get startNode() {
479
486
  return this._$AA;
@@ -482,7 +489,7 @@ class R {
482
489
  return this._$AB;
483
490
  }
484
491
  _$AI(t, i = this) {
485
- t = S(this, t, i), d(t) ? t === A$2 || null == t || "" === t ? (this._$AH !== A$2 && this._$AR(), this._$AH = A$2) : t !== this._$AH && t !== T && this._(t) : void 0 !== t._$litType$ ? this.g(t) : void 0 !== t.nodeType ? this.$(t) : v(t) ? this.T(t) : this._(t);
492
+ t = N$1(this, t, i), c$4(t) ? t === T || null == t || "" === t ? (this._$AH !== T && this._$AR(), this._$AH = T) : t !== this._$AH && t !== w$1 && this._(t) : void 0 !== t._$litType$ ? this.g(t) : void 0 !== t.nodeType ? this.$(t) : u(t) ? this.T(t) : this._(t);
486
493
  }
487
494
  k(t) {
488
495
  return this._$AA.parentNode.insertBefore(t, this._$AB);
@@ -491,104 +498,98 @@ class R {
491
498
  this._$AH !== t && (this._$AR(), this._$AH = this.k(t));
492
499
  }
493
500
  _(t) {
494
- this._$AH !== A$2 && d(this._$AH) ? this._$AA.nextSibling.data = t : this.$(r$2.createTextNode(t)), this._$AH = t;
501
+ this._$AH !== T && c$4(this._$AH) ? this._$AA.nextSibling.data = t : this.$(r$3.createTextNode(t)), this._$AH = t;
495
502
  }
496
503
  g(t) {
497
- var i;
498
504
  const {
499
- values: s,
500
- _$litType$: e
505
+ values: i,
506
+ _$litType$: s
501
507
  } = t,
502
- o = "number" == typeof e ? this._$AC(t) : (void 0 === e.el && (e.el = N$1.createElement(P(e.h, e.h[0]), this.options)), e);
503
- if ((null === (i = this._$AH) || void 0 === i ? void 0 : i._$AD) === o) this._$AH.v(s);else {
504
- const t = new M$1(o, this),
505
- i = t.u(this.options);
506
- t.v(s), this.$(i), this._$AH = t;
508
+ e = "number" == typeof s ? this._$AC(t) : (void 0 === s.el && (s.el = V.createElement(C$1(s.h, s.h[0]), this.options)), s);
509
+ if (this._$AH?._$AD === e) this._$AH.p(i);else {
510
+ const t = new S(e, this),
511
+ s = t.u(this.options);
512
+ t.p(i), this.$(s), this._$AH = t;
507
513
  }
508
514
  }
509
515
  _$AC(t) {
510
- let i = E$1.get(t.strings);
511
- return void 0 === i && E$1.set(t.strings, i = new N$1(t)), i;
516
+ let i = A$2.get(t.strings);
517
+ return void 0 === i && A$2.set(t.strings, i = new V(t)), i;
512
518
  }
513
519
  T(t) {
514
- c$4(this._$AH) || (this._$AH = [], this._$AR());
520
+ a$2(this._$AH) || (this._$AH = [], this._$AR());
515
521
  const i = this._$AH;
516
522
  let s,
517
523
  e = 0;
518
- for (const o of t) e === i.length ? i.push(s = new R(this.k(u()), this.k(u()), this, this.options)) : s = i[e], s._$AI(o), e++;
524
+ for (const h of t) e === i.length ? i.push(s = new M(this.k(l()), this.k(l()), this, this.options)) : s = i[e], s._$AI(h), e++;
519
525
  e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
520
526
  }
521
527
  _$AR(t = this._$AA.nextSibling, i) {
522
- var s;
523
- for (null === (s = this._$AP) || void 0 === s || s.call(this, !1, !0, i); t && t !== this._$AB;) {
528
+ for (this._$AP?.(!1, !0, i); t && t !== this._$AB;) {
524
529
  const i = t.nextSibling;
525
530
  t.remove(), t = i;
526
531
  }
527
532
  }
528
533
  setConnected(t) {
529
- var i;
530
- void 0 === this._$AM && (this._$Cp = t, null === (i = this._$AP) || void 0 === i || i.call(this, t));
531
- }
532
- }
533
- let k$1 = class k {
534
- constructor(t, i, s, e, o) {
535
- this.type = 1, this._$AH = A$2, this._$AN = void 0, this.element = t, this.name = i, this._$AM = e, this.options = o, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = A$2;
534
+ void 0 === this._$AM && (this._$Cv = t, this._$AP?.(t));
536
535
  }
536
+ };
537
+ class R {
537
538
  get tagName() {
538
539
  return this.element.tagName;
539
540
  }
540
541
  get _$AU() {
541
542
  return this._$AM._$AU;
542
543
  }
544
+ constructor(t, i, s, e, h) {
545
+ this.type = 1, this._$AH = T, 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 = T;
546
+ }
543
547
  _$AI(t, i = this, s, e) {
544
- const o = this.strings;
545
- let n = !1;
546
- if (void 0 === o) t = S(this, t, i, 0), n = !d(t) || t !== this._$AH && t !== T, n && (this._$AH = t);else {
548
+ const h = this.strings;
549
+ let o = !1;
550
+ if (void 0 === h) t = N$1(this, t, i, 0), o = !c$4(t) || t !== this._$AH && t !== w$1, o && (this._$AH = t);else {
547
551
  const e = t;
548
- let l, h;
549
- for (t = o[0], l = 0; l < o.length - 1; l++) h = S(this, e[s + l], i, l), h === T && (h = this._$AH[l]), n || (n = !d(h) || h !== this._$AH[l]), h === A$2 ? t = A$2 : t !== A$2 && (t += (null != h ? h : "") + o[l + 1]), this._$AH[l] = h;
552
+ let n, r;
553
+ for (t = h[0], n = 0; n < h.length - 1; n++) r = N$1(this, e[s + n], i, n), r === w$1 && (r = this._$AH[n]), o ||= !c$4(r) || r !== this._$AH[n], r === T ? t = T : t !== T && (t += (r ?? "") + h[n + 1]), this._$AH[n] = r;
550
554
  }
551
- n && !e && this.j(t);
555
+ o && !e && this.O(t);
552
556
  }
553
- j(t) {
554
- t === A$2 ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, null != t ? t : "");
557
+ O(t) {
558
+ t === T ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
555
559
  }
556
- };
557
- class H extends k$1 {
560
+ }
561
+ let k$1 = class k extends R {
558
562
  constructor() {
559
563
  super(...arguments), this.type = 3;
560
564
  }
561
- j(t) {
562
- this.element[this.name] = t === A$2 ? void 0 : t;
565
+ O(t) {
566
+ this.element[this.name] = t === T ? void 0 : t;
563
567
  }
564
- }
565
- const I = s$3 ? s$3.emptyScript : "";
566
- class L extends k$1 {
568
+ };
569
+ class H extends R {
567
570
  constructor() {
568
571
  super(...arguments), this.type = 4;
569
572
  }
570
- j(t) {
571
- t && t !== A$2 ? this.element.setAttribute(this.name, I) : this.element.removeAttribute(this.name);
573
+ O(t) {
574
+ this.element.toggleAttribute(this.name, !!t && t !== T);
572
575
  }
573
576
  }
574
- class z extends k$1 {
575
- constructor(t, i, s, e, o) {
576
- super(t, i, s, e, o), this.type = 5;
577
+ class I extends R {
578
+ constructor(t, i, s, e, h) {
579
+ super(t, i, s, e, h), this.type = 5;
577
580
  }
578
581
  _$AI(t, i = this) {
579
- var s;
580
- if ((t = null !== (s = S(this, t, i, 0)) && void 0 !== s ? s : A$2) === T) return;
581
- const e = this._$AH,
582
- o = t === A$2 && e !== A$2 || t.capture !== e.capture || t.once !== e.once || t.passive !== e.passive,
583
- n = t !== A$2 && (e === A$2 || o);
584
- o && this.element.removeEventListener(this.name, this, e), n && this.element.addEventListener(this.name, this, t), this._$AH = t;
582
+ if ((t = N$1(this, t, i, 0) ?? T) === w$1) return;
583
+ const s = this._$AH,
584
+ e = t === T && s !== T || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive,
585
+ h = t !== T && (s === T || e);
586
+ e && this.element.removeEventListener(this.name, this, s), h && this.element.addEventListener(this.name, this, t), this._$AH = t;
585
587
  }
586
588
  handleEvent(t) {
587
- var i, s;
588
- "function" == typeof this._$AH ? this._$AH.call(null !== (s = null === (i = this.options) || void 0 === i ? void 0 : i.host) && void 0 !== s ? s : this.element, t) : this._$AH.handleEvent(t);
589
+ "function" == typeof this._$AH ? this._$AH.call(this.options?.host ?? this.element, t) : this._$AH.handleEvent(t);
589
590
  }
590
591
  }
591
- class Z {
592
+ class L {
592
593
  constructor(t, i, s) {
593
594
  this.element = t, this.type = 6, this._$AN = void 0, this._$AM = i, this.options = s;
594
595
  }
@@ -596,20 +597,19 @@ class Z {
596
597
  return this._$AM._$AU;
597
598
  }
598
599
  _$AI(t) {
599
- S(this, t);
600
+ N$1(this, t);
600
601
  }
601
602
  }
602
- const B$1 = i$2.litHtmlPolyfillSupport;
603
- null == B$1 || B$1(N$1, R), (null !== (t$1 = i$2.litHtmlVersions) && void 0 !== t$1 ? t$1 : i$2.litHtmlVersions = []).push("2.8.0");
604
- const D$1 = (t, i, s) => {
605
- var e, o;
606
- const n = null !== (e = null == s ? void 0 : s.renderBefore) && void 0 !== e ? e : i;
607
- let l = n._$litPart$;
608
- if (void 0 === l) {
609
- const t = null !== (o = null == s ? void 0 : s.renderBefore) && void 0 !== o ? o : null;
610
- n._$litPart$ = l = new R(i.insertBefore(u(), t), t, void 0, null != s ? s : {});
603
+ const Z = t$1.litHtmlPolyfillSupport;
604
+ Z?.(V, M$1), (t$1.litHtmlVersions ??= []).push("3.1.0");
605
+ const j$1 = (t, i, s) => {
606
+ const e = s?.renderBefore ?? i;
607
+ let h = e._$litPart$;
608
+ if (void 0 === h) {
609
+ const t = s?.renderBefore ?? null;
610
+ e._$litPart$ = h = new M$1(i.insertBefore(l(), t), t, void 0, s ?? {});
611
611
  }
612
- return l._$AI(t), l;
612
+ return h._$AI(t), h;
613
613
  };
614
614
 
615
615
  /**
@@ -617,42 +617,38 @@ const D$1 = (t, i, s) => {
617
617
  * Copyright 2017 Google LLC
618
618
  * SPDX-License-Identifier: BSD-3-Clause
619
619
  */
620
- var l$2, o$1;
621
- let s$2 = class s extends u$1 {
620
+ let s$2 = class s extends b$2 {
622
621
  constructor() {
623
622
  super(...arguments), this.renderOptions = {
624
623
  host: this
625
624
  }, this._$Do = void 0;
626
625
  }
627
626
  createRenderRoot() {
628
- var t, e;
629
- const i = super.createRenderRoot();
630
- return null !== (t = (e = this.renderOptions).renderBefore) && void 0 !== t || (e.renderBefore = i.firstChild), i;
627
+ const t = super.createRenderRoot();
628
+ return this.renderOptions.renderBefore ??= t.firstChild, t;
631
629
  }
632
630
  update(t) {
633
631
  const i = this.render();
634
- this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = D$1(i, this.renderRoot, this.renderOptions);
632
+ this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = j$1(i, this.renderRoot, this.renderOptions);
635
633
  }
636
634
  connectedCallback() {
637
- var t;
638
- super.connectedCallback(), null === (t = this._$Do) || void 0 === t || t.setConnected(!0);
635
+ super.connectedCallback(), this._$Do?.setConnected(!0);
639
636
  }
640
637
  disconnectedCallback() {
641
- var t;
642
- super.disconnectedCallback(), null === (t = this._$Do) || void 0 === t || t.setConnected(!1);
638
+ super.disconnectedCallback(), this._$Do?.setConnected(!1);
643
639
  }
644
640
  render() {
645
- return T;
641
+ return w$1;
646
642
  }
647
643
  };
648
- s$2.finalized = !0, s$2._$litElement$ = !0, null === (l$2 = globalThis.litElementHydrateSupport) || void 0 === l$2 || l$2.call(globalThis, {
644
+ s$2._$litElement$ = !0, s$2[("finalized")] = !0, globalThis.litElementHydrateSupport?.({
649
645
  LitElement: s$2
650
646
  });
651
- const n$2 = globalThis.litElementPolyfillSupport;
652
- null == n$2 || n$2({
647
+ const r$2 = globalThis.litElementPolyfillSupport;
648
+ r$2?.({
653
649
  LitElement: s$2
654
650
  });
655
- (null !== (o$1 = globalThis.litElementVersions) && void 0 !== o$1 ? o$1 : globalThis.litElementVersions = []).push("3.3.3");
651
+ (globalThis.litElementVersions ??= []).push("4.0.2");
656
652
 
657
653
  function ascending$1(a, b) {
658
654
  return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
@@ -5617,7 +5613,6 @@ function clipAntimeridianLine(stream) {
5617
5613
  }
5618
5614
  };
5619
5615
  }
5620
-
5621
5616
  function clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {
5622
5617
  var cosPhi0,
5623
5618
  cosPhi1,
@@ -5887,7 +5882,6 @@ function clipRectangle(x0, y0, x1, y1) {
5887
5882
  function corner(p, direction) {
5888
5883
  return abs(p[0] - x0) < epsilon$1 ? direction > 0 ? 0 : 3 : abs(p[0] - x1) < epsilon$1 ? direction > 0 ? 2 : 1 : abs(p[1] - y0) < epsilon$1 ? direction > 0 ? 1 : 0 : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon
5889
5884
  }
5890
-
5891
5885
  function compareIntersection(a, b) {
5892
5886
  return comparePoint(a.x, b.x);
5893
5887
  }
@@ -7759,7 +7753,6 @@ function timeInterval(floori, offseti, count, field) {
7759
7753
  }
7760
7754
  });
7761
7755
  };
7762
-
7763
7756
  if (count) {
7764
7757
  interval.count = (start, end) => {
7765
7758
  t0.setTime(+start), t1.setTime(+end);
@@ -10340,7 +10333,6 @@ class DecidablesElement extends s$2 {
10340
10333
  };
10341
10334
  /* eslint-enable key-spacing, object-curly-newline */
10342
10335
  }
10343
-
10344
10336
  static cssBoxShadow(elevation, rotate = false, inverse = false) {
10345
10337
  const umbraO = this.shadows.opacityUmbra + this.shadows.opacityBoost;
10346
10338
  const penumbraO = this.shadows.opacityPenumbra + this.shadows.opacityBoost;
@@ -10443,24 +10435,24 @@ class DecidablesElement extends s$2 {
10443
10435
  `;
10444
10436
  }
10445
10437
  static get styles() {
10446
- return i$3`
10438
+ return i$4`
10447
10439
  :host {
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)});
10440
+ ---shadow-0: var(--shadow-0, ${r$5(this.cssBoxShadow(0))});
10441
+ ---shadow-2: var(--shadow-2, ${r$5(this.cssBoxShadow(2))});
10442
+ ---shadow-4: var(--shadow-4, ${r$5(this.cssBoxShadow(4))});
10443
+ ---shadow-8: var(--shadow-8, ${r$5(this.cssBoxShadow(8))});
10444
+
10445
+ ---color-background: var(--color-background, ${r$5(this.greys.white)});
10446
+ ---color-border: var(--color-border, ${r$5(this.greys.light75)});
10447
+ ---color-text: var(--color-text, ${r$5(this.greys.dark75)});
10448
+ ---color-text-inverse: var(--color-text-inverse, ${r$5(this.greys.white)});
10449
+ ---color-link: var(--color-link, ${r$5(this.greys.dark25)});
10450
+ ---color-element-background: var(--color-element-background, ${r$5(this.greys.light75)});
10451
+ ---color-element-disabled: var(--color-element-disabled, ${r$5(this.greys.light50)});
10452
+ ---color-element-enabled: var(--color-element-enabled, ${r$5(this.greys.dark25)});
10453
+ ---color-element-selected: var(--color-element-selected, ${r$5(this.greys.grey)});
10454
+ ---color-element-border: var(--color-element-border, ${r$5(this.greys.dark50)});
10455
+ ---color-element-emphasis: var(--color-element-emphasis, ${r$5(this.greys.dark75)});
10464
10456
 
10465
10457
  ---font-family-base: var(--font-family-base, "Source Sans", sans-serif);
10466
10458
  ---font-family-math: var(--font-family-math, "Source Serif", serif);
@@ -10521,7 +10513,7 @@ class DecidablesButton extends DecidablesElement {
10521
10513
  this.disabled = false;
10522
10514
  }
10523
10515
  static get styles() {
10524
- return [super.styles, i$3`
10516
+ return [super.styles, i$4`
10525
10517
  :host {
10526
10518
  margin: 0.25rem;
10527
10519
  }
@@ -10591,7 +10583,7 @@ customElements.define('decidables-button', DecidablesButton);
10591
10583
  * Copyright 2018 Google LLC
10592
10584
  * SPDX-License-Identifier: BSD-3-Clause
10593
10585
  */
10594
- const l$1 = l => null != l ? l : A$2;
10586
+ const o$2 = o => o ?? T;
10595
10587
 
10596
10588
  class DecidablesSlider extends DecidablesElement {
10597
10589
  static get properties() {
@@ -10646,11 +10638,11 @@ class DecidablesSlider extends DecidablesElement {
10646
10638
  this.value = event.target.value;
10647
10639
  }
10648
10640
  static get styles() {
10649
- return [super.styles, i$3`
10641
+ return [super.styles, i$4`
10650
10642
  :host {
10651
- ---shadow-2-rotate: var(--shadow-2-rotate, ${r$4(this.cssBoxShadow(2, true, false))});
10652
- ---shadow-4-rotate: var(--shadow-4-rotate, ${r$4(this.cssBoxShadow(4, true, false))});
10653
- ---shadow-8-rotate: var(--shadow-8-rotate, ${r$4(this.cssBoxShadow(8, true, false))});
10643
+ ---shadow-2-rotate: var(--shadow-2-rotate, ${r$5(this.cssBoxShadow(2, true, false))});
10644
+ ---shadow-4-rotate: var(--shadow-4-rotate, ${r$5(this.cssBoxShadow(4, true, false))});
10645
+ ---shadow-8-rotate: var(--shadow-8-rotate, ${r$5(this.cssBoxShadow(8, true, false))});
10654
10646
 
10655
10647
  display: flex;
10656
10648
 
@@ -10904,9 +10896,9 @@ class DecidablesSlider extends DecidablesElement {
10904
10896
  <slot></slot>
10905
10897
  </label>
10906
10898
  <div class="range">
10907
- <input type="range" id="slider" min=${l$1(this.min)} max=${l$1(this.max)} step=${l$1(this.step)} .value=${this.value} @change=${this.changed.bind(this)} @input=${this.inputted.bind(this)}>
10899
+ <input type="range" id="slider" min=${o$2(this.min)} max=${o$2(this.max)} step=${o$2(this.step)} .value=${this.value} @change=${this.changed.bind(this)} @input=${this.inputted.bind(this)}>
10908
10900
  </div>
10909
- <decidables-spinner min=${l$1(this.min)} max=${l$1(this.max)} step=${l$1(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}></decidables-spinner>
10901
+ <decidables-spinner min=${o$2(this.min)} max=${o$2(this.max)} step=${o$2(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}></decidables-spinner>
10910
10902
  `;
10911
10903
  }
10912
10904
  }
@@ -10956,7 +10948,7 @@ class DecidablesSpinner extends DecidablesElement {
10956
10948
  this.value = event.target.value;
10957
10949
  }
10958
10950
  static get styles() {
10959
- return [super.styles, i$3`
10951
+ return [super.styles, i$4`
10960
10952
  :host {
10961
10953
  ---decidables-spinner-font-size: var(--decidables-spinner-font-size, 1.125rem);
10962
10954
  ---decidables-spinner-input-width: var(--decidables-spinner-input-width, 4rem);
@@ -11056,7 +11048,7 @@ class DecidablesSpinner extends DecidablesElement {
11056
11048
  return x$2`
11057
11049
  <label>
11058
11050
  <slot></slot>
11059
- <input ?disabled=${this.disabled} type="number" min=${l$1(this.min)} max=${l$1(this.max)} step=${l$1(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}>
11051
+ <input ?disabled=${this.disabled} type="number" min=${o$2(this.min)} max=${o$2(this.max)} step=${o$2(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}>
11060
11052
  </label>
11061
11053
  `;
11062
11054
  }
@@ -11095,7 +11087,7 @@ class DecidablesSwitch extends DecidablesElement {
11095
11087
  }));
11096
11088
  }
11097
11089
  static get styles() {
11098
- return [super.styles, i$3`
11090
+ return [super.styles, i$4`
11099
11091
  :host {
11100
11092
  display: flex;
11101
11093
 
@@ -11247,7 +11239,7 @@ class DecidablesToggle extends DecidablesElement {
11247
11239
  this.disabled = false;
11248
11240
  }
11249
11241
  static get styles() {
11250
- return [super.styles, i$3`
11242
+ return [super.styles, i$4`
11251
11243
  fieldset {
11252
11244
  display: flex;
11253
11245
 
@@ -11322,7 +11314,7 @@ class DecidablesToggleOption extends DecidablesElement {
11322
11314
  }));
11323
11315
  }
11324
11316
  static get styles() {
11325
- return [super.styles, i$3`
11317
+ return [super.styles, i$4`
11326
11318
  :host {
11327
11319
  display: flex;
11328
11320
  }
@@ -11496,12 +11488,11 @@ class DiscountableElement extends DecidablesElement {
11496
11488
  d: schemeSet1[1],
11497
11489
  k: schemeSet1[2],
11498
11490
  v: schemeSet1[3],
11499
- chosen: schemeSet1[8],
11500
- better: '#4545d0',
11501
- worse: '#f032e6',
11502
- even: '#10dbc9',
11503
- correct: '#ffffff',
11504
- error: '#000000',
11491
+ sooner: schemeSet1[5],
11492
+ later: schemeSet1[7],
11493
+ larger: '#4545d0',
11494
+ smaller: '#f032e6',
11495
+ equal: '#10dbc9',
11505
11496
  nr: '#cccccc'
11506
11497
  };
11507
11498
  }
@@ -11518,43 +11509,40 @@ class DiscountableElement extends DecidablesElement {
11518
11509
  }, {});
11519
11510
  }
11520
11511
  static get styles() {
11521
- return [super.styles, i$3`
11512
+ return [super.styles, i$4`
11522
11513
  :host {
11523
- ---color-a: var(--color-a, ${r$4(this.colors.a)});
11524
- ---color-d: var(--color-d, ${r$4(this.colors.d)});
11525
- ---color-k: var(--color-k, ${r$4(this.colors.k)});
11526
- ---color-v: var(--color-v, ${r$4(this.colors.v)});
11527
- ---color-chosen: var(--color-chosen, ${r$4(this.colors.chosen)});
11528
- ---color-better: var(--color-better, ${r$4(this.colors.better)});
11529
- ---color-worse: var(--color-worse, ${r$4(this.colors.worse)});
11530
- ---color-even: var(--color-even, ${r$4(this.colors.even)});
11531
- ---color-correct: var(--color-correct, ${r$4(this.colors.correct)});
11532
- ---color-error: var(--color-error, ${r$4(this.colors.error)});
11533
- ---color-nr: var(--color-nr, ${r$4(this.colors.nr)});
11534
-
11535
- ---color-a-light: var(--color-a-light, ${r$4(this.lights.a)});
11536
- ---color-d-light: var(--color-d-light, ${r$4(this.lights.d)});
11537
- ---color-k-light: var(--color-k-light, ${r$4(this.lights.k)});
11538
- ---color-v-light: var(--color-v-light, ${r$4(this.lights.v)});
11539
- ---color-chosen-light: var(--color-chosen-light, ${r$4(this.lights.chosen)});
11540
- ---color-better-light: var(--color-better-light, ${r$4(this.lights.better)});
11541
- ---color-worse-light: var(--color-worse-light, ${r$4(this.lights.worse)});
11542
- ---color-even-light: var(--color-even-light, ${r$4(this.lights.even)});
11543
- ---color-correct-light: var(--color-correct-light, ${r$4(this.lights.correct)});
11544
- ---color-error-light: var(--color-error-light, ${r$4(this.lights.error)});
11545
- ---color-nr-light: var(--color-nr-light, ${r$4(this.lights.nr)});
11546
-
11547
- ---color-a-dark: var(--color-a-dark, ${r$4(this.darks.a)});
11548
- ---color-d-dark: var(--color-d-dark, ${r$4(this.darks.d)});
11549
- ---color-k-dark: var(--color-k-dark, ${r$4(this.darks.k)});
11550
- ---color-v-dark: var(--color-v-dark, ${r$4(this.darks.v)});
11551
- ---color-chosen-dark: var(--color-chosen-dark, ${r$4(this.darks.chosen)});
11552
- ---color-better-dark: var(--color-better-dark, ${r$4(this.darks.better)});
11553
- ---color-worse-dark: var(--color-worse-dark, ${r$4(this.darks.worse)});
11554
- ---color-even-dark: var(--color-even-dark, ${r$4(this.darks.even)});
11555
- ---color-correct-dark: var(--color-correct-dark, ${r$4(this.darks.correct)});
11556
- ---color-error-dark: var(--color-error-dark, ${r$4(this.darks.error)});
11557
- ---color-nr-dark: var(--color-nr-dark, ${r$4(this.darks.nr)});
11514
+ ---color-a: var(--color-a, ${r$5(this.colors.a)});
11515
+ ---color-d: var(--color-d, ${r$5(this.colors.d)});
11516
+ ---color-k: var(--color-k, ${r$5(this.colors.k)});
11517
+ ---color-v: var(--color-v, ${r$5(this.colors.v)});
11518
+ ---color-sooner: var(--color-sooner, ${r$5(this.colors.sooner)});
11519
+ ---color-later: var(--color-later, ${r$5(this.colors.later)});
11520
+ ---color-larger: var(--color-larger, ${r$5(this.colors.larger)});
11521
+ ---color-smaller: var(--color-smaller, ${r$5(this.colors.smaller)});
11522
+ ---color-equal: var(--color-equal, ${r$5(this.colors.equal)});
11523
+ ---color-nr: var(--color-nr, ${r$5(this.colors.nr)});
11524
+
11525
+ ---color-a-light: var(--color-a-light, ${r$5(this.lights.a)});
11526
+ ---color-d-light: var(--color-d-light, ${r$5(this.lights.d)});
11527
+ ---color-k-light: var(--color-k-light, ${r$5(this.lights.k)});
11528
+ ---color-v-light: var(--color-v-light, ${r$5(this.lights.v)});
11529
+ ---color-sooner-light: var(--color-sooner-light, ${r$5(this.lights.sooner)});
11530
+ ---color-later-light: var(--color-later-light, ${r$5(this.lights.later)});
11531
+ ---color-larger-light: var(--color-larger-light, ${r$5(this.lights.larger)});
11532
+ ---color-smaller-light: var(--color-smaller-light, ${r$5(this.lights.smaller)});
11533
+ ---color-equal-light: var(--color-equal-light, ${r$5(this.lights.equal)});
11534
+ ---color-nr-light: var(--color-nr-light, ${r$5(this.lights.nr)});
11535
+
11536
+ ---color-a-dark: var(--color-a-dark, ${r$5(this.darks.a)});
11537
+ ---color-d-dark: var(--color-d-dark, ${r$5(this.darks.d)});
11538
+ ---color-k-dark: var(--color-k-dark, ${r$5(this.darks.k)});
11539
+ ---color-v-dark: var(--color-v-dark, ${r$5(this.darks.v)});
11540
+ ---color-sooner-dark: var(--color-sooner-dark, ${r$5(this.darks.sooner)});
11541
+ ---color-later-dark: var(--color-later-dark, ${r$5(this.darks.later)});
11542
+ ---color-larger-dark: var(--color-larger-dark, ${r$5(this.darks.larger)});
11543
+ ---color-smaller-dark: var(--color-smaller-dark, ${r$5(this.darks.smaller)});
11544
+ ---color-equal-dark: var(--color-equal-dark, ${r$5(this.darks.equal)});
11545
+ ---color-nr-dark: var(--color-nr-dark, ${r$5(this.darks.nr)});
11558
11546
  }
11559
11547
  `];
11560
11548
  }
@@ -11659,7 +11647,7 @@ class DiscountableControl extends DiscountableElement {
11659
11647
  this.state = 'ended';
11660
11648
  }
11661
11649
  static get styles() {
11662
- return [super.styles, i$3`
11650
+ return [super.styles, i$4`
11663
11651
  :host {
11664
11652
  display: inline-block;
11665
11653
  }
@@ -11759,7 +11747,6 @@ class DiscountableResponse extends DiscountableElement {
11759
11747
  this.responses = ['first', 'second', 'nr']; // Possible values of 'response'
11760
11748
  this.response = undefined; // Response for current trial
11761
11749
  }
11762
-
11763
11750
  start(as, ds, al, dl, trial) {
11764
11751
  this.state = 'waiting';
11765
11752
  this.as = as;
@@ -11802,7 +11789,7 @@ class DiscountableResponse extends DiscountableElement {
11802
11789
  this.response = undefined;
11803
11790
  }
11804
11791
  static get styles() {
11805
- return [super.styles, i$3`
11792
+ return [super.styles, i$4`
11806
11793
  :host {
11807
11794
  display: inline-block;
11808
11795
  }
@@ -11850,11 +11837,11 @@ class DiscountableResponse extends DiscountableElement {
11850
11837
  }
11851
11838
 
11852
11839
  .selected[disabled][name="first"] {
11853
- --decidables-button-background-color: var(---color-worse);
11840
+ --decidables-button-background-color: var(---color-sooner);
11854
11841
  }
11855
11842
 
11856
11843
  .selected[disabled][name="second"] {
11857
- --decidables-button-background-color: var(---color-better);
11844
+ --decidables-button-background-color: var(---color-later);
11858
11845
  }
11859
11846
 
11860
11847
  /* Feedback messages */
@@ -11887,11 +11874,11 @@ class DiscountableResponse extends DiscountableElement {
11887
11874
  }
11888
11875
 
11889
11876
  .feedback.first {
11890
- background-color: var(---color-worse-light);
11877
+ background-color: var(---color-sooner-light);
11891
11878
  }
11892
11879
 
11893
11880
  .feedback.second {
11894
- background-color: var(---color-better-light);
11881
+ background-color: var(---color-later-light);
11895
11882
  }
11896
11883
 
11897
11884
  .feedback.nr {
@@ -11950,7 +11937,7 @@ const t = {
11950
11937
  EVENT: 5,
11951
11938
  ELEMENT: 6
11952
11939
  },
11953
- e$1 = t => (...e) => ({
11940
+ e = t => (...e) => ({
11954
11941
  _$litDirective$: t,
11955
11942
  values: e
11956
11943
  });
@@ -11975,7 +11962,7 @@ let i$1 = class i {
11975
11962
  * Copyright 2020 Google LLC
11976
11963
  * SPDX-License-Identifier: BSD-3-Clause
11977
11964
  */
11978
- const e = o => void 0 === o.strings;
11965
+ const f$1 = o => void 0 === o.strings;
11979
11966
 
11980
11967
  /**
11981
11968
  * @license
@@ -11983,41 +11970,39 @@ const e = o => void 0 === o.strings;
11983
11970
  * SPDX-License-Identifier: BSD-3-Clause
11984
11971
  */
11985
11972
  const s = (i, t) => {
11986
- var e, o;
11987
- const r = i._$AN;
11988
- if (void 0 === r) return !1;
11989
- for (const i of r) null === (o = (e = i)._$AO) || void 0 === o || o.call(e, t, !1), s(i, t);
11973
+ const e = i._$AN;
11974
+ if (void 0 === e) return !1;
11975
+ for (const i of e) i._$AO?.(t, !1), s(i, t);
11990
11976
  return !0;
11991
11977
  },
11992
- o = i => {
11978
+ o$1 = i => {
11993
11979
  let t, e;
11994
11980
  do {
11995
11981
  if (void 0 === (t = i._$AM)) break;
11996
11982
  e = t._$AN, e.delete(i), i = t;
11997
- } while (0 === (null == e ? void 0 : e.size));
11983
+ } while (0 === e?.size);
11998
11984
  },
11999
11985
  r$1 = i => {
12000
11986
  for (let t; t = i._$AM; i = t) {
12001
11987
  let e = t._$AN;
12002
11988
  if (void 0 === e) t._$AN = e = new Set();else if (e.has(i)) break;
12003
- e.add(i), l(t);
11989
+ e.add(i), c(t);
12004
11990
  }
12005
11991
  };
12006
- function n$1(i) {
12007
- void 0 !== this._$AN ? (o(this), this._$AM = i, r$1(this)) : this._$AM = i;
11992
+ function h(i) {
11993
+ void 0 !== this._$AN ? (o$1(this), this._$AM = i, r$1(this)) : this._$AM = i;
12008
11994
  }
12009
- function h$1(i, t = !1, e = 0) {
11995
+ function n$1(i, t = !1, e = 0) {
12010
11996
  const r = this._$AH,
12011
- n = this._$AN;
12012
- if (void 0 !== n && 0 !== n.size) if (t) {
12013
- if (Array.isArray(r)) for (let i = e; i < r.length; i++) s(r[i], !1), o(r[i]);else null != r && (s(r, !1), o(r));
11997
+ h = this._$AN;
11998
+ if (void 0 !== h && 0 !== h.size) if (t) {
11999
+ if (Array.isArray(r)) for (let i = e; i < r.length; i++) s(r[i], !1), o$1(r[i]);else null != r && (s(r, !1), o$1(r));
12014
12000
  } else s(this, i);
12015
12001
  }
12016
- const l = i => {
12017
- var t$1, s, o, r;
12018
- i.type == t.CHILD && (null !== (t$1 = (o = i)._$AP) && void 0 !== t$1 || (o._$AP = h$1), null !== (s = (r = i)._$AQ) && void 0 !== s || (r._$AQ = n$1));
12002
+ const c = i => {
12003
+ i.type == t.CHILD && (i._$AP ??= n$1, i._$AQ ??= h);
12019
12004
  };
12020
- class c extends i$1 {
12005
+ class f extends i$1 {
12021
12006
  constructor() {
12022
12007
  super(...arguments), this._$AN = void 0;
12023
12008
  }
@@ -12025,11 +12010,10 @@ class c extends i$1 {
12025
12010
  super._$AT(i, t, e), r$1(this), this.isConnected = i._$AU;
12026
12011
  }
12027
12012
  _$AO(i, t = !0) {
12028
- var e, r;
12029
- i !== this.isConnected && (this.isConnected = i, i ? null === (e = this.reconnected) || void 0 === e || e.call(this) : null === (r = this.disconnected) || void 0 === r || r.call(this)), t && (s(this, i), o(this));
12013
+ i !== this.isConnected && (this.isConnected = i, i ? this.reconnected?.() : this.disconnected?.()), t && (s(this, i), o$1(this));
12030
12014
  }
12031
12015
  setValue(t) {
12032
- if (e(this._$Ct)) this._$Ct._$AI(t, this);else {
12016
+ if (f$1(this._$Ct)) this._$Ct._$AI(t, this);else {
12033
12017
  const i = [...this._$Ct._$AH];
12034
12018
  i[this._$Ci] = t, this._$Ct._$AI(i, this, 0);
12035
12019
  }
@@ -12040,11 +12024,11 @@ class c extends i$1 {
12040
12024
 
12041
12025
  const i = new WeakMap();
12042
12026
 
12043
- let h = 0;
12027
+ let o = 0;
12044
12028
  const r = new Map(),
12045
12029
  n = new WeakSet(),
12046
12030
  a = () => new Promise(t => requestAnimationFrame(t)),
12047
- p = [{
12031
+ v = [{
12048
12032
  opacity: 0
12049
12033
  }, {
12050
12034
  opacity: 1
@@ -12103,60 +12087,54 @@ const r = new Map(),
12103
12087
  },
12104
12088
  b = ["left", "top", "width", "height", "opacity", "color", "background"],
12105
12089
  j = new WeakMap();
12106
- class x extends c {
12090
+ class x extends f {
12107
12091
  constructor(t$1) {
12108
12092
  if (super(t$1), this.t = null, this.i = null, this.o = !0, this.shouldLog = !1, t$1.type === t.CHILD) throw Error("The `animate` directive must be used in attribute position.");
12109
12093
  this.createFinished();
12110
12094
  }
12111
12095
  createFinished() {
12112
- var t;
12113
- null === (t = this.resolveFinished) || void 0 === t || t.call(this), this.finished = new Promise(t => {
12096
+ this.resolveFinished?.(), this.finished = new Promise(t => {
12114
12097
  this.h = t;
12115
12098
  });
12116
12099
  }
12117
12100
  async resolveFinished() {
12118
- var t;
12119
- null === (t = this.h) || void 0 === t || t.call(this), this.h = void 0;
12101
+ this.h?.(), this.h = void 0;
12120
12102
  }
12121
12103
  render(i) {
12122
- return A$2;
12104
+ return T;
12123
12105
  }
12124
12106
  getController() {
12125
12107
  return i.get(this.l);
12126
12108
  }
12127
12109
  isDisabled() {
12128
- var t;
12129
- return this.options.disabled || (null === (t = this.getController()) || void 0 === t ? void 0 : t.disabled);
12110
+ return this.options.disabled || this.getController()?.disabled;
12130
12111
  }
12131
12112
  update(t, [i]) {
12132
- var s;
12133
- const e = void 0 === this.l;
12134
- return e && (this.l = null === (s = t.options) || void 0 === s ? void 0 : s.host, this.l.addController(this), this.element = t.element, j.set(this.element, this)), this.optionsOrCallback = i, (e || "function" != typeof i) && this.u(i), this.render(i);
12113
+ const s = void 0 === this.l;
12114
+ return s && (this.l = t.options?.host, this.l.addController(this), this.element = t.element, j.set(this.element, this)), this.optionsOrCallback = i, (s || "function" != typeof i) && this.u(i), this.render(i);
12135
12115
  }
12136
12116
  u(t) {
12137
- var i, s;
12138
- t = null != t ? t : {};
12139
- const e = this.getController();
12140
- void 0 !== e && ((t = {
12141
- ...e.defaultOptions,
12117
+ t = t ?? {};
12118
+ const i = this.getController();
12119
+ void 0 !== i && ((t = {
12120
+ ...i.defaultOptions,
12142
12121
  ...t
12143
12122
  }).keyframeOptions = {
12144
- ...e.defaultOptions.keyframeOptions,
12123
+ ...i.defaultOptions.keyframeOptions,
12145
12124
  ...t.keyframeOptions
12146
- }), null !== (i = (s = t).properties) && void 0 !== i || (s.properties = b), this.options = t;
12125
+ }), t.properties ??= b, this.options = t;
12147
12126
  }
12148
- v() {
12127
+ p() {
12149
12128
  const t = {},
12150
12129
  i = this.element.getBoundingClientRect(),
12151
12130
  s = getComputedStyle(this.element);
12152
12131
  return this.options.properties.forEach(e => {
12153
- var o;
12154
- const h = null !== (o = i[e]) && void 0 !== o ? o : N[e] ? void 0 : s[e],
12155
- r = Number(h);
12156
- t[e] = isNaN(r) ? h + "" : r;
12132
+ const h = i[e] ?? (N[e] ? void 0 : s[e]),
12133
+ o = Number(h);
12134
+ t[e] = isNaN(o) ? h + "" : o;
12157
12135
  }), t;
12158
12136
  }
12159
- p() {
12137
+ m() {
12160
12138
  let t,
12161
12139
  i = !0;
12162
12140
  return this.options.guard && (t = this.options.guard(), i = ((t, i) => {
@@ -12164,11 +12142,10 @@ class x extends c {
12164
12142
  if (Array.isArray(i) && i.length === t.length && t.every((t, s) => t === i[s])) return !1;
12165
12143
  } else if (i === t) return !1;
12166
12144
  return !0;
12167
- })(t, this.m)), this.o = this.l.hasUpdated && !this.isDisabled() && !this.isAnimating() && i && this.element.isConnected, this.o && (this.m = Array.isArray(t) ? Array.from(t) : t), this.o;
12145
+ })(t, this.v)), this.o = this.l.hasUpdated && !this.isDisabled() && !this.isAnimating() && i && this.element.isConnected, this.o && (this.v = Array.isArray(t) ? Array.from(t) : t), this.o;
12168
12146
  }
12169
12147
  hostUpdate() {
12170
- var t;
12171
- "function" == typeof this.optionsOrCallback && this.u(this.optionsOrCallback()), this.p() && (this.g = this.v(), this.t = null !== (t = this.t) && void 0 !== t ? t : this.element.parentNode, this.i = this.element.nextSibling);
12148
+ "function" == typeof this.optionsOrCallback && this.u(this.optionsOrCallback()), this.m() && (this.g = this.p(), this.t = this.t ?? this.element.parentNode, this.i = this.element.nextSibling);
12172
12149
  }
12173
12150
  async hostUpdated() {
12174
12151
  if (!this.o || !this.element.isConnected || this.options.skipInitial && !this.isHostRendered) return;
@@ -12176,69 +12153,64 @@ class x extends c {
12176
12153
  this.prepare(), await a;
12177
12154
  const i = this._(),
12178
12155
  s = this.A(this.options.keyframeOptions, i),
12179
- e = this.v();
12156
+ e = this.p();
12180
12157
  if (void 0 !== this.g) {
12181
12158
  const {
12182
12159
  from: s,
12183
- to: o
12160
+ to: h
12184
12161
  } = this.O(this.g, e, i);
12185
- this.log("measured", [this.g, e, s, o]), t = this.calculateKeyframes(s, o);
12162
+ this.log("measured", [this.g, e, s, h]), t = this.calculateKeyframes(s, h);
12186
12163
  } else {
12187
12164
  const s = r.get(this.options.inId);
12188
12165
  if (s) {
12189
12166
  r.delete(this.options.inId);
12190
12167
  const {
12191
- from: o,
12168
+ from: h,
12192
12169
  to: n
12193
12170
  } = this.O(s, e, i);
12194
- t = this.calculateKeyframes(o, n), t = this.options.in ? [{
12171
+ t = this.calculateKeyframes(h, n), t = this.options.in ? [{
12195
12172
  ...this.options.in[0],
12196
12173
  ...t[0]
12197
- }, ...this.options.in.slice(1), t[1]] : t, h++, t.forEach(t => t.zIndex = h);
12174
+ }, ...this.options.in.slice(1), t[1]] : t, o++, t.forEach(t => t.zIndex = o);
12198
12175
  } else this.options.in && (t = [...this.options.in, {}]);
12199
12176
  }
12200
12177
  this.animate(t, s);
12201
12178
  }
12202
12179
  resetStyles() {
12203
- var t;
12204
- void 0 !== this.j && (this.element.setAttribute("style", null !== (t = this.j) && void 0 !== t ? t : ""), this.j = void 0);
12180
+ void 0 !== this.j && (this.element.setAttribute("style", this.j ?? ""), this.j = void 0);
12205
12181
  }
12206
12182
  commitStyles() {
12207
- var t, i;
12208
- this.j = this.element.getAttribute("style"), null === (t = this.webAnimation) || void 0 === t || t.commitStyles(), null === (i = this.webAnimation) || void 0 === i || i.cancel();
12183
+ this.j = this.element.getAttribute("style"), this.webAnimation?.commitStyles(), this.webAnimation?.cancel();
12209
12184
  }
12210
12185
  reconnected() {}
12211
12186
  async disconnected() {
12212
- var t;
12213
12187
  if (!this.o) return;
12214
12188
  if (void 0 !== this.options.id && r.set(this.options.id, this.g), void 0 === this.options.out) return;
12215
- if (this.prepare(), await a(), null === (t = this.t) || void 0 === t ? void 0 : t.isConnected) {
12189
+ if (this.prepare(), await a(), this.t?.isConnected) {
12216
12190
  const t = this.i && this.i.parentNode === this.t ? this.i : null;
12217
12191
  if (this.t.insertBefore(this.element, t), this.options.stabilizeOut) {
12218
- const t = this.v();
12192
+ const t = this.p();
12219
12193
  this.log("stabilizing out");
12220
12194
  const i = this.g.left - t.left,
12221
12195
  s = this.g.top - t.top;
12222
12196
  !("static" === getComputedStyle(this.element).position) || 0 === i && 0 === s || (this.element.style.position = "relative"), 0 !== i && (this.element.style.left = i + "px"), 0 !== s && (this.element.style.top = s + "px");
12223
12197
  }
12224
12198
  }
12225
- const i = this.A(this.options.keyframeOptions);
12226
- await this.animate(this.options.out, i), this.element.remove();
12199
+ const t = this.A(this.options.keyframeOptions);
12200
+ await this.animate(this.options.out, t), this.element.remove();
12227
12201
  }
12228
12202
  prepare() {
12229
12203
  this.createFinished();
12230
12204
  }
12231
12205
  start() {
12232
- var t, i;
12233
- null === (i = (t = this.options).onStart) || void 0 === i || i.call(t, this);
12206
+ this.options.onStart?.(this);
12234
12207
  }
12235
12208
  didFinish(t) {
12236
- var i, s;
12237
- t && (null === (s = (i = this.options).onComplete) || void 0 === s || s.call(i, this)), this.g = void 0, this.animatingProperties = void 0, this.frames = void 0, this.resolveFinished();
12209
+ t && this.options.onComplete?.(this), this.g = void 0, this.animatingProperties = void 0, this.frames = void 0, this.resolveFinished();
12238
12210
  }
12239
12211
  _() {
12240
12212
  const t = [];
12241
- for (let i = this.element.parentNode; i; i = null == i ? void 0 : i.parentNode) {
12213
+ for (let i = this.element.parentNode; i; i = i?.parentNode) {
12242
12214
  const s = j.get(i);
12243
12215
  s && !s.isDisabled() && s && t.push(s);
12244
12216
  }
@@ -12263,32 +12235,31 @@ class x extends c {
12263
12235
  ...i
12264
12236
  };
12265
12237
  const e = s.map(t => t.animatingProperties).filter(t => void 0 !== t);
12266
- let o = 1,
12267
- h = 1;
12238
+ let h = 1,
12239
+ o = 1;
12268
12240
  return void 0 !== e && (e.forEach(t => {
12269
- t.width && (o /= t.width), t.height && (h /= t.height);
12270
- }), void 0 !== t.left && void 0 !== i.left && (t.left = o * t.left, i.left = o * i.left), void 0 !== t.top && void 0 !== i.top && (t.top = h * t.top, i.top = h * i.top)), {
12241
+ t.width && (h /= t.width), t.height && (o /= t.height);
12242
+ }), 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)), {
12271
12243
  from: t,
12272
12244
  to: i
12273
12245
  };
12274
12246
  }
12275
12247
  calculateKeyframes(t, i, s = !1) {
12276
- var e;
12277
- const o = {},
12248
+ const e = {},
12278
12249
  h = {};
12279
- let r = !1;
12280
- const n = {};
12250
+ let o = !1;
12251
+ const r = {};
12281
12252
  for (const s in i) {
12282
- const a = t[s],
12283
- l = i[s];
12253
+ const n = t[s],
12254
+ a = i[s];
12284
12255
  if (s in N) {
12285
12256
  const t = N[s];
12286
- if (void 0 === a || void 0 === l) continue;
12287
- const i = t(a, l);
12288
- void 0 !== i.transform && (n[s] = i.value, r = !0, o.transform = `${null !== (e = o.transform) && void 0 !== e ? e : ""} ${i.transform}`, void 0 !== i.overrideFrom && Object.assign(o, i.overrideFrom));
12289
- } else a !== l && void 0 !== a && void 0 !== l && (r = !0, o[s] = a, h[s] = l);
12257
+ if (void 0 === n || void 0 === a) continue;
12258
+ const i = t(n, a);
12259
+ void 0 !== i.transform && (r[s] = i.value, o = !0, e.transform = `${e.transform ?? ""} ${i.transform}`, void 0 !== i.overrideFrom && Object.assign(e, i.overrideFrom));
12260
+ } else n !== a && void 0 !== n && void 0 !== a && (o = !0, e[s] = n, h[s] = a);
12290
12261
  }
12291
- return o.transformOrigin = h.transformOrigin = s ? "center center" : "top left", this.animatingProperties = n, r ? [o, h] : void 0;
12262
+ return e.transformOrigin = h.transformOrigin = s ? "center center" : "top left", this.animatingProperties = r, o ? [e, h] : void 0;
12292
12263
  }
12293
12264
  async animate(t, i = this.options.keyframeOptions) {
12294
12265
  this.start(), this.frames = t;
@@ -12296,23 +12267,22 @@ class x extends c {
12296
12267
  if (!this.isAnimating() && !this.isDisabled() && (this.options.onFrames && (this.frames = t = this.options.onFrames(this), this.log("modified frames", t)), void 0 !== t)) {
12297
12268
  this.log("animate", [t, i]), s = !0, this.webAnimation = this.element.animate(t, i);
12298
12269
  const e = this.getController();
12299
- null == e || e.add(this);
12270
+ e?.add(this);
12300
12271
  try {
12301
12272
  await this.webAnimation.finished;
12302
12273
  } catch (t) {}
12303
- null == e || e.remove(this);
12274
+ e?.remove(this);
12304
12275
  }
12305
12276
  return this.didFinish(s), s;
12306
12277
  }
12307
12278
  isAnimating() {
12308
- var t, i;
12309
- return "running" === (null === (t = this.webAnimation) || void 0 === t ? void 0 : t.playState) || (null === (i = this.webAnimation) || void 0 === i ? void 0 : i.pending);
12279
+ return "running" === this.webAnimation?.playState || this.webAnimation?.pending;
12310
12280
  }
12311
12281
  log(t, i) {
12312
12282
  this.shouldLog && !this.isDisabled() && console.log(t, this.options.id, i);
12313
12283
  }
12314
12284
  }
12315
- const F = e$1(x);
12285
+ const F = e(x);
12316
12286
 
12317
12287
  /*
12318
12288
  HTDMath Static Class - Not intended for instantiation!
@@ -12355,7 +12325,7 @@ class HTDEquation extends DiscountableElement {
12355
12325
  this.numeric = false;
12356
12326
  }
12357
12327
  static get styles() {
12358
- return [super.styles, i$3`
12328
+ return [super.styles, i$4`
12359
12329
  :host {
12360
12330
  display: block;
12361
12331
 
@@ -12623,7 +12593,7 @@ class HTDCalculation extends HTDEquation {
12623
12593
  this.sendEvent();
12624
12594
  }
12625
12595
  static get styles() {
12626
- return [super.styles, i$3`
12596
+ return [super.styles, i$4`
12627
12597
  /* :host {
12628
12598
  display: inline-block;
12629
12599
  } */
@@ -12670,11 +12640,11 @@ class HTDCalculation extends HTDEquation {
12670
12640
  <var class="math-var">V<sub class="subscript">ll</sub></var>
12671
12641
  </decidables-spinner>`;
12672
12642
  vDiff = x$2`${this.vDiff > 0 ? x$2`<span class="comparison" ${F({
12673
- in: p
12643
+ in: v
12674
12644
  })}>&gt;</span>` : this.vDiff < 0 ? x$2`<span class="comparison" ${F({
12675
- in: p
12645
+ in: v
12676
12646
  })}>&lt;</span>` : x$2`<span class="comparison" ${F({
12677
- in: p
12647
+ in: v
12678
12648
  })}>=</span>`}`;
12679
12649
  } else {
12680
12650
  as = x$2`<var class="math-var a as">A<sub class="subscript">ss</sub></var>`;
@@ -12907,7 +12877,7 @@ class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {
12907
12877
  this.requestUpdate();
12908
12878
  }
12909
12879
  static get styles() {
12910
- return [super.styles, i$3`
12880
+ return [super.styles, i$4`
12911
12881
  :host {
12912
12882
  display: inline-block;
12913
12883
 
@@ -13060,7 +13030,6 @@ class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {
13060
13030
  // ${DiscountableElement.svgFilters}
13061
13031
  // `;
13062
13032
  }
13063
-
13064
13033
  update(changedProperties) {
13065
13034
  super.update(changedProperties);
13066
13035
  this.alignState();
@@ -13289,7 +13258,6 @@ class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {
13289
13258
  break;
13290
13259
  // no-op
13291
13260
  }
13292
-
13293
13261
  keyK = keyK < this.scale.discount.min ? this.scale.discount.min : keyK > this.scale.discount.max ? this.scale.discount.max : this.scale.discount.round(keyK);
13294
13262
  if (keyK !== this.k) {
13295
13263
  this.k = keyK;
@@ -13358,7 +13326,6 @@ class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {
13358
13326
  break;
13359
13327
  // no-op
13360
13328
  }
13361
-
13362
13329
  keyD = keyD < this.scale.time.min ? this.scale.time.min : keyD > this.scale.time.max ? this.scale.time.max : keyD;
13363
13330
  if (keyD !== datum.d) {
13364
13331
  datum.d = keyD;
@@ -13430,7 +13397,6 @@ class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {
13430
13397
  break;
13431
13398
  // no-op
13432
13399
  }
13433
-
13434
13400
  keyA = keyA < this.scale.value.min ? this.scale.value.min : keyA > this.scale.value.max ? this.scale.value.max : keyA;
13435
13401
  if (keyA !== datum.a) {
13436
13402
  datum.a = keyA;
@@ -13623,7 +13589,6 @@ const tickIntervals = [["millisecond", 1], ["2 milliseconds", 2], ["5 millisecon
13623
13589
  // https://github.com/d3/d3-time/issues/46
13624
13590
  ["year", durationYear], ["2 years", 2 * durationYear], ["5 years", 5 * durationYear], ["10 years", 10 * durationYear], ["20 years", 20 * durationYear], ["50 years", 50 * durationYear], ["100 years", 100 * durationYear] // TODO generalize to longer time scales
13625
13591
  ];
13626
-
13627
13592
  const durations = new Map([["second", durationSecond], ["minute", durationMinute], ["hour", durationHour], ["day", durationDay], ["monday", durationWeek], ["tuesday", durationWeek], ["wednesday", durationWeek], ["thursday", durationWeek], ["friday", durationWeek], ["saturday", durationWeek], ["sunday", durationWeek], ["week", durationWeek], ["month", durationMonth], ["year", durationYear]]);
13628
13593
  const timeIntervals = new Map([["second", second$1], ["minute", timeMinute], ["hour", timeHour], ["day", timeDay],
13629
13594
  // https://github.com/d3/d3-time/issues/62
@@ -14183,7 +14148,6 @@ function isColor(value) {
14183
14148
  namedColors.has(value) // currentColor, red, etc.
14184
14149
  ;
14185
14150
  }
14186
-
14187
14151
  function isOpacity(value) {
14188
14152
  return typeof value === "number" && (0 <= value && value <= 1 || isNaN(value));
14189
14153
  }
@@ -15255,7 +15219,6 @@ function applyClip(selection, mark, dimensions, context) {
15255
15219
  this.appendChild(selection.node());
15256
15220
  selection.node = () => this; // Note: mutation!
15257
15221
  });
15258
-
15259
15222
  break;
15260
15223
  }
15261
15224
  case "sphere":
@@ -15823,7 +15786,6 @@ function createScaleQ(key, scale, channels, {
15823
15786
  range = Float64Array.from(domain, (_, i) => i / (domain.length - 1));
15824
15787
  if (range.length === 2) range = unit; // optimize common case of [0, 1]
15825
15788
  }
15826
-
15827
15789
  scale.interpolate((range === unit ? constant : interpolatePiecewise)(interpolate));
15828
15790
  } else {
15829
15791
  scale.interpolate(interpolate);
@@ -15842,7 +15804,6 @@ function createScaleQ(key, scale, channels, {
15842
15804
  else domain[0] = 0; // [1, 2] or [-1, -2]
15843
15805
  }
15844
15806
  }
15845
-
15846
15807
  if (reverse$1) domain = reverse(domain);
15847
15808
  scale.domain(domain).unknown(unknown);
15848
15809
  if (nice) scale.nice(maybeNice(nice, type)), domain = scale.domain();
@@ -15941,7 +15902,6 @@ function createScaleQuantize(key, channels, {
15941
15902
  thresholds = quantize(interpolateNumber(min, max), n + 1).slice(1, -1); // exactly n - 1 thresholds to match range
15942
15903
  if (min instanceof Date) thresholds = thresholds.map(x => new Date(x)); // preserve date types
15943
15904
  }
15944
-
15945
15905
  if (orderof(arrayify(domain)) < 0) thresholds.reverse(); // preserve descending domain
15946
15906
  return createScaleThreshold(key, channels, {
15947
15907
  domain: thresholds,
@@ -16254,7 +16214,6 @@ function createScaleOrdinal(key, channels, {
16254
16214
  range = maybeBooleanRange(domain, scheme);
16255
16215
  if (range !== undefined) scheme = undefined; // Don’t re-apply scheme.
16256
16216
  }
16257
-
16258
16217
  if (scheme === undefined && range === undefined) {
16259
16218
  scheme = type === "ordinal" ? "turbo" : "tableau10";
16260
16219
  }
@@ -16339,7 +16298,6 @@ function inferHint(channels, key) {
16339
16298
  // first hint
16340
16299
  else if (value !== candidate) return; // inconsistent hint
16341
16300
  }
16342
-
16343
16301
  return value;
16344
16302
  }
16345
16303
  function inferSymbolHint(channels) {
@@ -17457,7 +17415,6 @@ function composeRender(r1, r2) {
17457
17415
  });
17458
17416
  };
17459
17417
  }
17460
-
17461
17418
  function maybeChannels(channels) {
17462
17419
  return Object.fromEntries(Object.entries(maybeNamed(channels)).map(([name, channel]) => {
17463
17420
  channel = typeof channel === "string" ? {
@@ -17474,7 +17431,6 @@ function maybeChannels(channels) {
17474
17431
  function maybeTip(tip) {
17475
17432
  return tip === true ? "xy" : tip === false || tip == null ? null : typeof tip === "string" ? keyword(tip, "tip", ["x", "y", "xy"]) : tip; // tip options object
17476
17433
  }
17477
-
17478
17434
  function withTip(options, pointer) {
17479
17435
  return options?.tip === true ? {
17480
17436
  ...options,
@@ -17683,7 +17639,6 @@ function pointerK(kx, ky, {
17683
17639
  else state.sticky = true, render(i);
17684
17640
  event.stopImmediatePropagation(); // suppress other pointers
17685
17641
  }
17686
-
17687
17642
  function pointerleave(event) {
17688
17643
  if (event.pointerType !== "mouse") return;
17689
17644
  if (!state.sticky) update(null);
@@ -19405,7 +19360,6 @@ function axisMark(mark, k, anchor, ariaLabel, data, options, initialize) {
19405
19360
  data = data.filter(d => domainSet.has(d));
19406
19361
  if (!data.length) warn(`Warning: the ${k}-axis ticks appear to not align with the scale domain, resulting in no ticks. Try different ticks?`); // prettier-ignore
19407
19362
  }
19408
-
19409
19363
  if (k === "y" || k === "x") {
19410
19364
  facets = [range(data)];
19411
19365
  } else {
@@ -19888,7 +19842,6 @@ class Tip extends Mark {
19888
19842
  ...format
19889
19843
  }; // defensive copy before mutate; also promote nullish to empty
19890
19844
  }
19891
-
19892
19845
  render(index, scales, values, dimensions, context) {
19893
19846
  const mark = this;
19894
19847
  const {
@@ -21407,7 +21360,6 @@ function maybeThresholds(thresholds, interval, defaultThresholds = thresholdAuto
21407
21360
  }
21408
21361
  return thresholds; // pass array, count, or function to bin.thresholds
21409
21362
  }
21410
-
21411
21363
  function maybeBinOutputs(outputs, inputs) {
21412
21364
  return maybeOutputs(outputs, inputs, maybeBinOutput);
21413
21365
  }
@@ -21713,7 +21665,6 @@ function stack(x, y = one, kx, ky, {
21713
21665
  if (y < 0) yn = Y2[i] = (Y1[i] = yn) + y;else if (y > 0) yp = Y2[i] = (Y1[i] = yp) + y;else Y2[i] = Y1[i] = yp; // NaN or zero
21714
21666
  }
21715
21667
  }
21716
-
21717
21668
  facetstacks.push(stacks);
21718
21669
  }
21719
21670
  if (offset) offset(facetstacks, Y1, Y2, Z);
@@ -22132,7 +22083,7 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
22132
22083
  };
22133
22084
  }
22134
22085
 
22135
- var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
	'use strict';

	var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};

	var distributions = {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();
	    }
	  })(commonjsGlobal, 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.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5];
	      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);
	var distributionsExports = distributions.exports;

	var mcmc = {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();
	    }
	  })(commonjsGlobal, 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);
	var mcmcExports = mcmc.exports;

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

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

	function compareDefined(compare = ascending) {
	  if (compare === ascending) 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;
	  if (valueof === undefined) {
	    for (const value of values) {
	      if (value != null && (max < value || max === undefined && value >= value)) {
	        max = value;
	      }
	    }
	  } else {
	    let index = -1;
	    for (let value of values) {
	      if ((value = valueof(value, ++index, values)) != null && (max < value || max === undefined && value >= value)) {
	        max = value;
	      }
	    }
	  }
	  return max;
	}

	function min(values, valueof) {
	  let min;
	  if (valueof === undefined) {
	    for (const value of values) {
	      if (value != null && (min > value || min === undefined && value >= value)) {
	        min = value;
	      }
	    }
	  } else {
	    let index = -1;
	    for (let value of values) {
	      if ((value = valueof(value, ++index, values)) != 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, valueof));
	  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, valueof);
	}

	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!

	  Variables:
	    A = amount
	    D = delay
	    V = subjective value

	    k = discount factor

	  Equations:
	    V = A / (1 + kD)
	*/
	class HTDMath {
	  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: 0,
	      upper: 100
	    },
	    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-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","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  Variables:\n    A = amount\n    D = delay\n    V = subjective value\n\n    k = discount factor\n\n  Equations:\n    V = A / (1 + kD)\n*/\nexport default class HTDMath {\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: 0, upper: 100},\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","index","compareDefined","compare","ascendingDefined","TypeError","quickselect","left","right","newLeft","newRight","swap","quantile","p","Float64Array","from","isNaN","i0","value0","subarray","value1","median","Transform","translate","apply","point","applyX","applyY","invert","invertX","invertY","rescaleX","copy","domain","range","map","rescaleY","HTDMath","adk2v","d","adv2k","self","onmessage","event","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]}', false);
22086
+ var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
	'use strict';

	var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};

	var distributions = {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();
	    }
	  })(commonjsGlobal, 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.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5];
	      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);
	var distributionsExports = distributions.exports;

	var mcmc = {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();
	    }
	  })(commonjsGlobal, 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);
	var mcmcExports = mcmc.exports;

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

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

	function compareDefined(compare = ascending) {
	  if (compare === ascending) 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;
	  if (valueof === undefined) {
	    for (const value of values) {
	      if (value != null && (max < value || max === undefined && value >= value)) {
	        max = value;
	      }
	    }
	  } else {
	    let index = -1;
	    for (let value of values) {
	      if ((value = valueof(value, ++index, values)) != null && (max < value || max === undefined && value >= value)) {
	        max = value;
	      }
	    }
	  }
	  return max;
	}

	function min(values, valueof) {
	  let min;
	  if (valueof === undefined) {
	    for (const value of values) {
	      if (value != null && (min > value || min === undefined && value >= value)) {
	        min = value;
	      }
	    }
	  } else {
	    let index = -1;
	    for (let value of values) {
	      if ((value = valueof(value, ++index, values)) != 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, valueof));
	  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, valueof);
	}

	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!

	  Variables:
	    A = amount
	    D = delay
	    V = subjective value

	    k = discount factor

	  Equations:
	    V = A / (1 + kD)
	*/
	class HTDMath {
	  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: 0,
	      upper: 100
	    },
	    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-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","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  Variables:\n    A = amount\n    D = delay\n    V = subjective value\n\n    k = discount factor\n\n  Equations:\n    V = A / (1 + kD)\n*/\nexport default class HTDMath {\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: 0, upper: 100},\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","index","compareDefined","compare","ascendingDefined","TypeError","quickselect","left","right","newLeft","newRight","swap","quantile","p","Float64Array","from","isNaN","i0","value0","subarray","value1","median","Transform","translate","apply","point","applyX","applyY","invert","invertX","invertY","rescaleX","copy","domain","range","map","rescaleY","HTDMath","adk2v","d","adv2k","self","onmessage","event","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]}', false);
22136
22087
  /* eslint-enable */
22137
22088
 
22138
22089
  /*
@@ -22216,7 +22167,7 @@ class HTDFit extends DiscountableElement {
22216
22167
  this.fit();
22217
22168
  }
22218
22169
  static get styles() {
22219
- return [super.styles, i$3`
22170
+ return [super.styles, i$4`
22220
22171
  /* :host {
22221
22172
  display: inline-block;
22222
22173
  } */
@@ -22332,7 +22283,7 @@ class ITCOption extends DiscountableElement {
22332
22283
  this.d = 0;
22333
22284
  }
22334
22285
  static get styles() {
22335
- return [super.styles, i$3`
22286
+ return [super.styles, i$4`
22336
22287
  :host {
22337
22288
  display: inline-block;
22338
22289
 
@@ -22355,7 +22306,7 @@ class ITCOption extends DiscountableElement {
22355
22306
 
22356
22307
  background: var(---color-element-background);
22357
22308
  border: 2px solid var(---color-element-emphasis);
22358
- border-radius: 50%;
22309
+ border-radius: var(---border-radius);
22359
22310
  }
22360
22311
 
22361
22312
  .interactive,
@@ -22487,7 +22438,7 @@ class ITCChoice extends DiscountableElement {
22487
22438
  this.dl = 30;
22488
22439
  }
22489
22440
  static get styles() {
22490
- return [super.styles, i$3`
22441
+ return [super.styles, i$4`
22491
22442
  :host {
22492
22443
  display: inline-block;
22493
22444
  }
@@ -22613,24 +22564,24 @@ class ITCTask extends DiscountableElement {
22613
22564
  // Decision parameters
22614
22565
  this.range = {};
22615
22566
  this.range.as = {
22616
- start: 10,
22567
+ start: 5,
22617
22568
  stop: 20,
22618
- step: 1
22569
+ step: 5
22619
22570
  }; // Amount SS
22620
22571
  this.range.ds = {
22621
- start: 10,
22622
- stop: 40,
22623
- step: 1
22572
+ start: 5,
22573
+ stop: 20,
22574
+ step: 5
22624
22575
  }; // Delay SS
22625
22576
  this.range.al = {
22626
- start: 20,
22627
- stop: 40,
22628
- step: 1
22577
+ start: 40,
22578
+ stop: 80,
22579
+ step: 5
22629
22580
  }; // Amount LL
22630
22581
  this.range.dl = {
22631
- start: 50,
22582
+ start: 40,
22632
22583
  stop: 80,
22633
- step: 1
22584
+ step: 5
22634
22585
  }; // Delay LL
22635
22586
 
22636
22587
  this.range.as.values = range$1(this.range.as.start, this.range.as.stop + 0.01, this.range.as.step);
@@ -22653,9 +22604,8 @@ class ITCTask extends DiscountableElement {
22653
22604
 
22654
22605
  this.runner = undefined; // D3 Interval for frame timing
22655
22606
  }
22656
-
22657
22607
  static get styles() {
22658
- return [super.styles, i$3`
22608
+ return [super.styles, i$4`
22659
22609
  :host {
22660
22610
  display: inline-block;
22661
22611
  }
@@ -22913,7 +22863,7 @@ customElements.define('htd-equation-adk2v', HTDEquationADK2V);
22913
22863
  */
22914
22864
  class HTDExample extends DiscountableElement {
22915
22865
  static get styles() {
22916
- return [super.styles, i$3`
22866
+ return [super.styles, i$4`
22917
22867
  :host {
22918
22868
  ---border: var(--border, 1px solid var(---color-border));
22919
22869
  display: inline-block;