@decidables/accumulable-elements 0.1.3 → 0.2.1
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.
- package/CHANGELOG.md +28 -0
- package/README.md +72 -33
- package/lib/accumulableElements.esm.js +733 -415
- package/lib/accumulableElements.esm.js.map +1 -1
- package/lib/accumulableElements.esm.min.js +300 -125
- package/lib/accumulableElements.esm.min.js.map +1 -1
- package/lib/accumulableElements.umd.js +733 -415
- package/lib/accumulableElements.umd.js.map +1 -1
- package/lib/accumulableElements.umd.min.js +301 -126
- package/lib/accumulableElements.umd.min.js.map +1 -1
- package/package.json +8 -8
- package/src/components/accumulable-control.js +4 -4
- package/src/components/accumulable-response.js +6 -24
- package/src/components/ddm-fit-worker.js +2 -2
- package/src/components/ddm-fit.js +6 -4
- package/src/components/ddm-model.js +130 -62
- package/src/components/ddm-parameters.js +61 -4
- package/src/equations/azv2pc.js +35 -8
- package/src/equations/azvt02m.js +44 -10
- package/src/examples/human.js +156 -71
- package/src/examples/interactive.js +39 -9
- package/src/examples/model.js +95 -93
|
@@ -10,20 +10,20 @@
|
|
|
10
10
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
11
11
|
*/
|
|
12
12
|
const t$1 = globalThis,
|
|
13
|
-
e$2 = t$1.ShadowRoot && (
|
|
14
|
-
s$
|
|
15
|
-
o$
|
|
13
|
+
e$2 = t$1.ShadowRoot && (void 0 === t$1.ShadyCSS || t$1.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
|
|
14
|
+
s$2 = Symbol(),
|
|
15
|
+
o$4 = new WeakMap();
|
|
16
16
|
let n$2 = class n {
|
|
17
17
|
constructor(t, e, o) {
|
|
18
|
-
if (this._$cssResult$ = true, o !== s$
|
|
18
|
+
if (this._$cssResult$ = true, o !== s$2) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
|
|
19
19
|
this.cssText = t, this.t = e;
|
|
20
20
|
}
|
|
21
21
|
get styleSheet() {
|
|
22
22
|
let t = this.o;
|
|
23
23
|
const s = this.t;
|
|
24
|
-
if (e$2 &&
|
|
25
|
-
const e =
|
|
26
|
-
e && (t = o$
|
|
24
|
+
if (e$2 && void 0 === t) {
|
|
25
|
+
const e = void 0 !== s && 1 === s.length;
|
|
26
|
+
e && (t = o$4.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$4.set(s, t));
|
|
27
27
|
}
|
|
28
28
|
return t;
|
|
29
29
|
}
|
|
@@ -31,26 +31,26 @@
|
|
|
31
31
|
return this.cssText;
|
|
32
32
|
}
|
|
33
33
|
};
|
|
34
|
-
const r$
|
|
34
|
+
const r$2 = t => new n$2("string" == typeof t ? t : t + "", void 0, s$2),
|
|
35
35
|
i$3 = (t, ...e) => {
|
|
36
36
|
const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
|
|
37
37
|
if (true === t._$cssResult$) return t.cssText;
|
|
38
38
|
if ("number" == typeof t) return t;
|
|
39
39
|
throw Error("Value passed to 'css' function must be a 'css' function result: " + t + ". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.");
|
|
40
40
|
})(s) + t[o + 1], t[0]);
|
|
41
|
-
return new n$2(o, t, s$
|
|
41
|
+
return new n$2(o, t, s$2);
|
|
42
42
|
},
|
|
43
43
|
S$1 = (s, o) => {
|
|
44
44
|
if (e$2) s.adoptedStyleSheets = o.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet);else for (const e of o) {
|
|
45
45
|
const o = document.createElement("style"),
|
|
46
46
|
n = t$1.litNonce;
|
|
47
|
-
|
|
47
|
+
void 0 !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
|
|
48
48
|
}
|
|
49
49
|
},
|
|
50
50
|
c$2 = e$2 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
|
|
51
51
|
let e = "";
|
|
52
52
|
for (const s of t.cssRules) e += s.cssText;
|
|
53
|
-
return r$
|
|
53
|
+
return r$2(e);
|
|
54
54
|
})(t) : t;
|
|
55
55
|
|
|
56
56
|
/**
|
|
@@ -61,9 +61,9 @@
|
|
|
61
61
|
const {
|
|
62
62
|
is: i$2,
|
|
63
63
|
defineProperty: e$1,
|
|
64
|
-
getOwnPropertyDescriptor:
|
|
65
|
-
getOwnPropertyNames:
|
|
66
|
-
getOwnPropertySymbols: o$
|
|
64
|
+
getOwnPropertyDescriptor: h$1,
|
|
65
|
+
getOwnPropertyNames: r$1,
|
|
66
|
+
getOwnPropertySymbols: o$3,
|
|
67
67
|
getPrototypeOf: n$1
|
|
68
68
|
} = Object,
|
|
69
69
|
a$1 = globalThis,
|
|
@@ -104,33 +104,34 @@
|
|
|
104
104
|
}
|
|
105
105
|
},
|
|
106
106
|
f$1 = (t, s) => !i$2(t, s),
|
|
107
|
-
|
|
107
|
+
b$1 = {
|
|
108
108
|
attribute: true,
|
|
109
109
|
type: String,
|
|
110
110
|
converter: u$1,
|
|
111
111
|
reflect: false,
|
|
112
|
+
useDefault: false,
|
|
112
113
|
hasChanged: f$1
|
|
113
114
|
};
|
|
114
115
|
Symbol.metadata ??= Symbol("metadata"), a$1.litPropertyMetadata ??= new WeakMap();
|
|
115
|
-
let
|
|
116
|
+
let y$2 = class y extends HTMLElement {
|
|
116
117
|
static addInitializer(t) {
|
|
117
118
|
this._$Ei(), (this.l ??= []).push(t);
|
|
118
119
|
}
|
|
119
120
|
static get observedAttributes() {
|
|
120
121
|
return this.finalize(), this._$Eh && [...this._$Eh.keys()];
|
|
121
122
|
}
|
|
122
|
-
static createProperty(t, s =
|
|
123
|
-
if (s.state && (s.attribute = false), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
|
|
123
|
+
static createProperty(t, s = b$1) {
|
|
124
|
+
if (s.state && (s.attribute = false), this._$Ei(), this.prototype.hasOwnProperty(t) && ((s = Object.create(s)).wrapped = true), this.elementProperties.set(t, s), !s.noAccessor) {
|
|
124
125
|
const i = Symbol(),
|
|
125
|
-
|
|
126
|
-
|
|
126
|
+
h = this.getPropertyDescriptor(t, i, s);
|
|
127
|
+
void 0 !== h && e$1(this.prototype, t, h);
|
|
127
128
|
}
|
|
128
129
|
}
|
|
129
130
|
static getPropertyDescriptor(t, s, i) {
|
|
130
131
|
const {
|
|
131
132
|
get: e,
|
|
132
|
-
set:
|
|
133
|
-
} =
|
|
133
|
+
set: r
|
|
134
|
+
} = h$1(this.prototype, t) ?? {
|
|
134
135
|
get() {
|
|
135
136
|
return this[s];
|
|
136
137
|
},
|
|
@@ -139,41 +140,39 @@
|
|
|
139
140
|
}
|
|
140
141
|
};
|
|
141
142
|
return {
|
|
142
|
-
get
|
|
143
|
-
return e?.call(this);
|
|
144
|
-
},
|
|
143
|
+
get: e,
|
|
145
144
|
set(s) {
|
|
146
|
-
const
|
|
147
|
-
|
|
145
|
+
const h = e?.call(this);
|
|
146
|
+
r?.call(this, s), this.requestUpdate(t, h, i);
|
|
148
147
|
},
|
|
149
148
|
configurable: true,
|
|
150
149
|
enumerable: true
|
|
151
150
|
};
|
|
152
151
|
}
|
|
153
152
|
static getPropertyOptions(t) {
|
|
154
|
-
return this.elementProperties.get(t) ??
|
|
153
|
+
return this.elementProperties.get(t) ?? b$1;
|
|
155
154
|
}
|
|
156
155
|
static _$Ei() {
|
|
157
156
|
if (this.hasOwnProperty(d$1("elementProperties"))) return;
|
|
158
157
|
const t = n$1(this);
|
|
159
|
-
t.finalize(),
|
|
158
|
+
t.finalize(), void 0 !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
|
|
160
159
|
}
|
|
161
160
|
static finalize() {
|
|
162
161
|
if (this.hasOwnProperty(d$1("finalized"))) return;
|
|
163
162
|
if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
|
|
164
163
|
const t = this.properties,
|
|
165
|
-
s = [...
|
|
164
|
+
s = [...r$1(t), ...o$3(t)];
|
|
166
165
|
for (const i of s) this.createProperty(i, t[i]);
|
|
167
166
|
}
|
|
168
167
|
const t = this[Symbol.metadata];
|
|
169
168
|
if (null !== t) {
|
|
170
169
|
const s = litPropertyMetadata.get(t);
|
|
171
|
-
if (
|
|
170
|
+
if (void 0 !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
|
|
172
171
|
}
|
|
173
172
|
this._$Eh = new Map();
|
|
174
173
|
for (const [t, s] of this.elementProperties) {
|
|
175
174
|
const i = this._$Eu(t, s);
|
|
176
|
-
|
|
175
|
+
void 0 !== i && this._$Eh.set(i, t);
|
|
177
176
|
}
|
|
178
177
|
this.elementStyles = this.finalizeStyles(this.styles);
|
|
179
178
|
}
|
|
@@ -182,21 +181,21 @@
|
|
|
182
181
|
if (Array.isArray(s)) {
|
|
183
182
|
const e = new Set(s.flat(1 / 0).reverse());
|
|
184
183
|
for (const s of e) i.unshift(c$2(s));
|
|
185
|
-
} else
|
|
184
|
+
} else void 0 !== s && i.push(c$2(s));
|
|
186
185
|
return i;
|
|
187
186
|
}
|
|
188
187
|
static _$Eu(t, s) {
|
|
189
188
|
const i = s.attribute;
|
|
190
|
-
return false === i ?
|
|
189
|
+
return false === i ? void 0 : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : void 0;
|
|
191
190
|
}
|
|
192
191
|
constructor() {
|
|
193
|
-
super(), this._$Ep =
|
|
192
|
+
super(), this._$Ep = void 0, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
|
|
194
193
|
}
|
|
195
194
|
_$Ev() {
|
|
196
195
|
this._$ES = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
|
|
197
196
|
}
|
|
198
197
|
addController(t) {
|
|
199
|
-
(this._$EO ??= new Set()).add(t),
|
|
198
|
+
(this._$EO ??= new Set()).add(t), void 0 !== this.renderRoot && this.isConnected && t.hostConnected?.();
|
|
200
199
|
}
|
|
201
200
|
removeController(t) {
|
|
202
201
|
this._$EO?.delete(t);
|
|
@@ -221,36 +220,44 @@
|
|
|
221
220
|
attributeChangedCallback(t, s, i) {
|
|
222
221
|
this._$AK(t, i);
|
|
223
222
|
}
|
|
224
|
-
_$
|
|
223
|
+
_$ET(t, s) {
|
|
225
224
|
const i = this.constructor.elementProperties.get(t),
|
|
226
225
|
e = this.constructor._$Eu(t, i);
|
|
227
|
-
if (
|
|
228
|
-
const
|
|
229
|
-
this._$Em = t, null ==
|
|
226
|
+
if (void 0 !== e && true === i.reflect) {
|
|
227
|
+
const h = (void 0 !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
|
|
228
|
+
this._$Em = t, null == h ? this.removeAttribute(e) : this.setAttribute(e, h), this._$Em = null;
|
|
230
229
|
}
|
|
231
230
|
}
|
|
232
231
|
_$AK(t, s) {
|
|
233
232
|
const i = this.constructor,
|
|
234
233
|
e = i._$Eh.get(t);
|
|
235
|
-
if (
|
|
234
|
+
if (void 0 !== e && this._$Em !== e) {
|
|
236
235
|
const t = i.getPropertyOptions(e),
|
|
237
|
-
|
|
236
|
+
h = "function" == typeof t.converter ? {
|
|
238
237
|
fromAttribute: t.converter
|
|
239
|
-
} :
|
|
240
|
-
this._$Em = e
|
|
238
|
+
} : void 0 !== t.converter?.fromAttribute ? t.converter : u$1;
|
|
239
|
+
this._$Em = e;
|
|
240
|
+
const r = h.fromAttribute(s, t.type);
|
|
241
|
+
this[e] = r ?? this._$Ej?.get(e) ?? r, this._$Em = null;
|
|
241
242
|
}
|
|
242
243
|
}
|
|
243
244
|
requestUpdate(t, s, i) {
|
|
244
|
-
if (
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
245
|
+
if (void 0 !== t) {
|
|
246
|
+
const e = this.constructor,
|
|
247
|
+
h = this[t];
|
|
248
|
+
if (i ??= e.getPropertyOptions(t), !((i.hasChanged ?? f$1)(h, s) || i.useDefault && i.reflect && h === this._$Ej?.get(t) && !this.hasAttribute(e._$Eu(t, i)))) return;
|
|
249
|
+
this.C(t, s, i);
|
|
250
|
+
}
|
|
251
|
+
false === this.isUpdatePending && (this._$ES = this._$EP());
|
|
252
|
+
}
|
|
253
|
+
C(t, s, {
|
|
254
|
+
useDefault: i,
|
|
255
|
+
reflect: e,
|
|
256
|
+
wrapped: h
|
|
257
|
+
}, r) {
|
|
258
|
+
i && !(this._$Ej ??= new Map()).has(t) && (this._$Ej.set(t, r ?? s ?? this[t]), true !== h || void 0 !== r) || (this._$AL.has(t) || (this.hasUpdated || i || (s = void 0), this._$AL.set(t, s)), true === e && this._$Em !== t && (this._$Eq ??= new Set()).add(t));
|
|
259
|
+
}
|
|
260
|
+
async _$EP() {
|
|
254
261
|
this.isUpdatePending = true;
|
|
255
262
|
try {
|
|
256
263
|
await this._$ES;
|
|
@@ -268,17 +275,23 @@
|
|
|
268
275
|
if (!this.hasUpdated) {
|
|
269
276
|
if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
|
|
270
277
|
for (const [t, s] of this._$Ep) this[t] = s;
|
|
271
|
-
this._$Ep =
|
|
278
|
+
this._$Ep = void 0;
|
|
272
279
|
}
|
|
273
280
|
const t = this.constructor.elementProperties;
|
|
274
|
-
if (t.size > 0) for (const [s, i] of t)
|
|
281
|
+
if (t.size > 0) for (const [s, i] of t) {
|
|
282
|
+
const {
|
|
283
|
+
wrapped: t
|
|
284
|
+
} = i,
|
|
285
|
+
e = this[s];
|
|
286
|
+
true !== t || this._$AL.has(s) || void 0 === e || this.C(s, void 0, i, e);
|
|
287
|
+
}
|
|
275
288
|
}
|
|
276
289
|
let t = false;
|
|
277
290
|
const s = this._$AL;
|
|
278
291
|
try {
|
|
279
|
-
t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$
|
|
292
|
+
t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EM();
|
|
280
293
|
} catch (s) {
|
|
281
|
-
throw t = false, this._$
|
|
294
|
+
throw t = false, this._$EM(), s;
|
|
282
295
|
}
|
|
283
296
|
t && this._$AE(s);
|
|
284
297
|
}
|
|
@@ -286,7 +299,7 @@
|
|
|
286
299
|
_$AE(t) {
|
|
287
300
|
this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t)), this.updated(t);
|
|
288
301
|
}
|
|
289
|
-
_$
|
|
302
|
+
_$EM() {
|
|
290
303
|
this._$AL = new Map(), this.isUpdatePending = false;
|
|
291
304
|
}
|
|
292
305
|
get updateComplete() {
|
|
@@ -299,16 +312,16 @@
|
|
|
299
312
|
return true;
|
|
300
313
|
}
|
|
301
314
|
update(t) {
|
|
302
|
-
this._$
|
|
315
|
+
this._$Eq &&= this._$Eq.forEach(t => this._$ET(t, this[t])), this._$EM();
|
|
303
316
|
}
|
|
304
317
|
updated(t) {}
|
|
305
318
|
firstUpdated(t) {}
|
|
306
319
|
};
|
|
307
|
-
|
|
320
|
+
y$2.elementStyles = [], y$2.shadowRootOptions = {
|
|
308
321
|
mode: "open"
|
|
309
|
-
},
|
|
310
|
-
ReactiveElement:
|
|
311
|
-
}), (a$1.reactiveElementVersions ??= []).push("2.
|
|
322
|
+
}, y$2[d$1("elementProperties")] = new Map(), y$2[d$1("finalized")] = new Map(), p$1?.({
|
|
323
|
+
ReactiveElement: y$2
|
|
324
|
+
}), (a$1.reactiveElementVersions ??= []).push("2.1.1");
|
|
312
325
|
|
|
313
326
|
/**
|
|
314
327
|
* @license
|
|
@@ -317,15 +330,15 @@
|
|
|
317
330
|
*/
|
|
318
331
|
const t = globalThis,
|
|
319
332
|
i$1 = t.trustedTypes,
|
|
320
|
-
s = i$1 ? i$1.createPolicy("lit-html", {
|
|
333
|
+
s$1 = i$1 ? i$1.createPolicy("lit-html", {
|
|
321
334
|
createHTML: t => t
|
|
322
|
-
}) :
|
|
335
|
+
}) : void 0,
|
|
323
336
|
e = "$lit$",
|
|
324
337
|
h = `lit$${Math.random().toFixed(9).slice(2)}$`,
|
|
325
|
-
o$
|
|
326
|
-
n = `<${o$
|
|
327
|
-
r
|
|
328
|
-
l = () => r
|
|
338
|
+
o$2 = "?" + h,
|
|
339
|
+
n = `<${o$2}>`,
|
|
340
|
+
r = document,
|
|
341
|
+
l = () => r.createComment(""),
|
|
329
342
|
c = t => null === t || "object" != typeof t && "function" != typeof t,
|
|
330
343
|
a = Array.isArray,
|
|
331
344
|
u = t => a(t) || "function" == typeof t?.[Symbol.iterator],
|
|
@@ -347,10 +360,10 @@
|
|
|
347
360
|
T = Symbol.for("lit-noChange"),
|
|
348
361
|
E = Symbol.for("lit-nothing"),
|
|
349
362
|
A = new WeakMap(),
|
|
350
|
-
C = r
|
|
363
|
+
C = r.createTreeWalker(r, 129);
|
|
351
364
|
function P(t, i) {
|
|
352
365
|
if (!a(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
|
|
353
|
-
return
|
|
366
|
+
return void 0 !== s$1 ? s$1.createHTML(i) : i;
|
|
354
367
|
}
|
|
355
368
|
const V = (t, i) => {
|
|
356
369
|
const s = t.length - 1,
|
|
@@ -364,7 +377,7 @@
|
|
|
364
377
|
u,
|
|
365
378
|
d = -1,
|
|
366
379
|
y = 0;
|
|
367
|
-
for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v :
|
|
380
|
+
for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v : 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, 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 : p) : c === g || c === p ? c = m : c === v || c === _ ? c = f : (c = m, r = void 0);
|
|
368
381
|
const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
|
|
369
382
|
l += c === f ? s + n : d >= 0 ? (o.push(a), s.slice(0, d) + e + s.slice(d) + h + x) : s + h + (-2 === d ? i : x);
|
|
370
383
|
}
|
|
@@ -415,7 +428,7 @@
|
|
|
415
428
|
r.append(t[s], l());
|
|
416
429
|
}
|
|
417
430
|
}
|
|
418
|
-
} else if (8 === r.nodeType) if (r.data === o$
|
|
431
|
+
} else if (8 === r.nodeType) if (r.data === o$2) d.push({
|
|
419
432
|
type: 2,
|
|
420
433
|
index: c
|
|
421
434
|
});else {
|
|
@@ -429,19 +442,19 @@
|
|
|
429
442
|
}
|
|
430
443
|
}
|
|
431
444
|
static createElement(t, i) {
|
|
432
|
-
const s = r
|
|
445
|
+
const s = r.createElement("template");
|
|
433
446
|
return s.innerHTML = t, s;
|
|
434
447
|
}
|
|
435
448
|
}
|
|
436
449
|
function S(t, i, s = t, e) {
|
|
437
450
|
if (i === T) return i;
|
|
438
|
-
let h =
|
|
439
|
-
const o = c(i) ?
|
|
440
|
-
return h?.constructor !== o && (h?._$AO?.(false),
|
|
451
|
+
let h = void 0 !== e ? s._$Co?.[e] : s._$Cl;
|
|
452
|
+
const o = c(i) ? void 0 : i._$litDirective$;
|
|
453
|
+
return h?.constructor !== o && (h?._$AO?.(false), void 0 === o ? h = void 0 : (h = new o(t), h._$AT(t, s, e)), void 0 !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), void 0 !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
|
|
441
454
|
}
|
|
442
455
|
class M {
|
|
443
456
|
constructor(t, i) {
|
|
444
|
-
this._$AV = [], this._$AN =
|
|
457
|
+
this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = i;
|
|
445
458
|
}
|
|
446
459
|
get parentNode() {
|
|
447
460
|
return this._$AM.parentNode;
|
|
@@ -456,24 +469,24 @@
|
|
|
456
469
|
},
|
|
457
470
|
parts: s
|
|
458
471
|
} = this._$AD,
|
|
459
|
-
e = (t?.creationScope ?? r
|
|
472
|
+
e = (t?.creationScope ?? r).importNode(i, true);
|
|
460
473
|
C.currentNode = e;
|
|
461
474
|
let h = C.nextNode(),
|
|
462
475
|
o = 0,
|
|
463
476
|
n = 0,
|
|
464
477
|
l = s[0];
|
|
465
|
-
for (;
|
|
478
|
+
for (; void 0 !== l;) {
|
|
466
479
|
if (o === l.index) {
|
|
467
480
|
let i;
|
|
468
481
|
2 === l.type ? i = new R(h, h.nextSibling, this, t) : 1 === l.type ? i = new l.ctor(h, l.name, l.strings, this, t) : 6 === l.type && (i = new z(h, this, t)), this._$AV.push(i), l = s[++n];
|
|
469
482
|
}
|
|
470
483
|
o !== l?.index && (h = C.nextNode(), o++);
|
|
471
484
|
}
|
|
472
|
-
return C.currentNode = r
|
|
485
|
+
return C.currentNode = r, e;
|
|
473
486
|
}
|
|
474
487
|
p(t) {
|
|
475
488
|
let i = 0;
|
|
476
|
-
for (const s of this._$AV)
|
|
489
|
+
for (const s of this._$AV) void 0 !== s && (void 0 !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
|
|
477
490
|
}
|
|
478
491
|
}
|
|
479
492
|
class R {
|
|
@@ -481,12 +494,12 @@
|
|
|
481
494
|
return this._$AM?._$AU ?? this._$Cv;
|
|
482
495
|
}
|
|
483
496
|
constructor(t, i, s, e) {
|
|
484
|
-
this.type = 2, this._$AH = E, this._$AN =
|
|
497
|
+
this.type = 2, this._$AH = E, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
|
|
485
498
|
}
|
|
486
499
|
get parentNode() {
|
|
487
500
|
let t = this._$AA.parentNode;
|
|
488
501
|
const i = this._$AM;
|
|
489
|
-
return
|
|
502
|
+
return void 0 !== i && 11 === t?.nodeType && (t = i.parentNode), t;
|
|
490
503
|
}
|
|
491
504
|
get startNode() {
|
|
492
505
|
return this._$AA;
|
|
@@ -495,7 +508,7 @@
|
|
|
495
508
|
return this._$AB;
|
|
496
509
|
}
|
|
497
510
|
_$AI(t, i = this) {
|
|
498
|
-
t = S(this, t, i), c(t) ? t === E || null == t || "" === t ? (this._$AH !== E && this._$AR(), this._$AH = E) : t !== this._$AH && t !== T && this._(t) :
|
|
511
|
+
t = S(this, t, i), c(t) ? t === E || null == t || "" === t ? (this._$AH !== E && this._$AR(), this._$AH = E) : t !== this._$AH && t !== T && this._(t) : void 0 !== t._$litType$ ? this.$(t) : void 0 !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
|
|
499
512
|
}
|
|
500
513
|
O(t) {
|
|
501
514
|
return this._$AA.parentNode.insertBefore(t, this._$AB);
|
|
@@ -504,14 +517,14 @@
|
|
|
504
517
|
this._$AH !== t && (this._$AR(), this._$AH = this.O(t));
|
|
505
518
|
}
|
|
506
519
|
_(t) {
|
|
507
|
-
this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r
|
|
520
|
+
this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r.createTextNode(t)), this._$AH = t;
|
|
508
521
|
}
|
|
509
522
|
$(t) {
|
|
510
523
|
const {
|
|
511
524
|
values: i,
|
|
512
525
|
_$litType$: s
|
|
513
526
|
} = t,
|
|
514
|
-
e = "number" == typeof s ? this._$AC(t) : (
|
|
527
|
+
e = "number" == typeof s ? this._$AC(t) : (void 0 === s.el && (s.el = N.createElement(P(s.h, s.h[0]), this.options)), s);
|
|
515
528
|
if (this._$AH?._$AD === e) this._$AH.p(i);else {
|
|
516
529
|
const t = new M(e, this),
|
|
517
530
|
s = t.u(this.options);
|
|
@@ -520,7 +533,7 @@
|
|
|
520
533
|
}
|
|
521
534
|
_$AC(t) {
|
|
522
535
|
let i = A.get(t.strings);
|
|
523
|
-
return
|
|
536
|
+
return void 0 === i && A.set(t.strings, i = new N(t)), i;
|
|
524
537
|
}
|
|
525
538
|
k(t) {
|
|
526
539
|
a(this._$AH) || (this._$AH = [], this._$AR());
|
|
@@ -531,13 +544,13 @@
|
|
|
531
544
|
e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
|
|
532
545
|
}
|
|
533
546
|
_$AR(t = this._$AA.nextSibling, i) {
|
|
534
|
-
for (this._$AP?.(false, true, i); t
|
|
547
|
+
for (this._$AP?.(false, true, i); t !== this._$AB;) {
|
|
535
548
|
const i = t.nextSibling;
|
|
536
549
|
t.remove(), t = i;
|
|
537
550
|
}
|
|
538
551
|
}
|
|
539
552
|
setConnected(t) {
|
|
540
|
-
|
|
553
|
+
void 0 === this._$AM && (this._$Cv = t, this._$AP?.(t));
|
|
541
554
|
}
|
|
542
555
|
}
|
|
543
556
|
class k {
|
|
@@ -548,12 +561,12 @@
|
|
|
548
561
|
return this._$AM._$AU;
|
|
549
562
|
}
|
|
550
563
|
constructor(t, i, s, e, h) {
|
|
551
|
-
this.type = 1, this._$AH = E, this._$AN =
|
|
564
|
+
this.type = 1, this._$AH = E, this._$AN = void 0, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E;
|
|
552
565
|
}
|
|
553
566
|
_$AI(t, i = this, s, e) {
|
|
554
567
|
const h = this.strings;
|
|
555
568
|
let o = false;
|
|
556
|
-
if (
|
|
569
|
+
if (void 0 === h) t = S(this, t, i, 0), o = !c(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
|
|
557
570
|
const e = t;
|
|
558
571
|
let n, r;
|
|
559
572
|
for (t = h[0], n = 0; n < h.length - 1; n++) r = S(this, e[s + n], i, n), r === T && (r = this._$AH[n]), o ||= !c(r) || r !== this._$AH[n], r === E ? t = E : t !== E && (t += (r ?? "") + h[n + 1]), this._$AH[n] = r;
|
|
@@ -569,7 +582,7 @@
|
|
|
569
582
|
super(...arguments), this.type = 3;
|
|
570
583
|
}
|
|
571
584
|
j(t) {
|
|
572
|
-
this.element[this.name] = t === E ?
|
|
585
|
+
this.element[this.name] = t === E ? void 0 : t;
|
|
573
586
|
}
|
|
574
587
|
}
|
|
575
588
|
class I extends k {
|
|
@@ -597,7 +610,7 @@
|
|
|
597
610
|
}
|
|
598
611
|
class z {
|
|
599
612
|
constructor(t, i, s) {
|
|
600
|
-
this.element = t, this.type = 6, this._$AN =
|
|
613
|
+
this.element = t, this.type = 6, this._$AN = void 0, this._$AM = i, this.options = s;
|
|
601
614
|
}
|
|
602
615
|
get _$AU() {
|
|
603
616
|
return this._$AM._$AU;
|
|
@@ -607,13 +620,13 @@
|
|
|
607
620
|
}
|
|
608
621
|
}
|
|
609
622
|
const j = t.litHtmlPolyfillSupport;
|
|
610
|
-
j?.(N, R), (t.litHtmlVersions ??= []).push("3.
|
|
623
|
+
j?.(N, R), (t.litHtmlVersions ??= []).push("3.3.1");
|
|
611
624
|
const B = (t, i, s) => {
|
|
612
625
|
const e = s?.renderBefore ?? i;
|
|
613
626
|
let h = e._$litPart$;
|
|
614
|
-
if (
|
|
627
|
+
if (void 0 === h) {
|
|
615
628
|
const t = s?.renderBefore ?? null;
|
|
616
|
-
e._$litPart$ = h = new R(i.insertBefore(l(), t), t,
|
|
629
|
+
e._$litPart$ = h = new R(i.insertBefore(l(), t), t, void 0, s ?? {});
|
|
617
630
|
}
|
|
618
631
|
return h._$AI(t), h;
|
|
619
632
|
};
|
|
@@ -623,19 +636,20 @@
|
|
|
623
636
|
* Copyright 2017 Google LLC
|
|
624
637
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
625
638
|
*/
|
|
626
|
-
|
|
639
|
+
const s = globalThis;
|
|
640
|
+
class i extends y$2 {
|
|
627
641
|
constructor() {
|
|
628
642
|
super(...arguments), this.renderOptions = {
|
|
629
643
|
host: this
|
|
630
|
-
}, this._$Do =
|
|
644
|
+
}, this._$Do = void 0;
|
|
631
645
|
}
|
|
632
646
|
createRenderRoot() {
|
|
633
647
|
const t = super.createRenderRoot();
|
|
634
648
|
return this.renderOptions.renderBefore ??= t.firstChild, t;
|
|
635
649
|
}
|
|
636
650
|
update(t) {
|
|
637
|
-
const
|
|
638
|
-
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(
|
|
651
|
+
const r = this.render();
|
|
652
|
+
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(r, this.renderRoot, this.renderOptions);
|
|
639
653
|
}
|
|
640
654
|
connectedCallback() {
|
|
641
655
|
super.connectedCallback(), this._$Do?.setConnected(true);
|
|
@@ -647,14 +661,14 @@
|
|
|
647
661
|
return T;
|
|
648
662
|
}
|
|
649
663
|
}
|
|
650
|
-
|
|
651
|
-
LitElement:
|
|
664
|
+
i._$litElement$ = true, i["finalized"] = true, s.litElementHydrateSupport?.({
|
|
665
|
+
LitElement: i
|
|
652
666
|
});
|
|
653
|
-
const
|
|
654
|
-
|
|
655
|
-
LitElement:
|
|
667
|
+
const o$1 = s.litElementPolyfillSupport;
|
|
668
|
+
o$1?.({
|
|
669
|
+
LitElement: i
|
|
656
670
|
});
|
|
657
|
-
(
|
|
671
|
+
(s.litElementVersions ??= []).push("4.2.1");
|
|
658
672
|
|
|
659
673
|
function ascending$1(a, b) {
|
|
660
674
|
return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
|
|
@@ -4572,7 +4586,7 @@
|
|
|
4572
4586
|
DecidablesElement Base Class - Not intended for instantiation!
|
|
4573
4587
|
<decidables-element>
|
|
4574
4588
|
*/
|
|
4575
|
-
class DecidablesElement extends
|
|
4589
|
+
class DecidablesElement extends i {
|
|
4576
4590
|
getComputedStyleValue(property) {
|
|
4577
4591
|
return getComputedStyle(this).getPropertyValue(property).trim();
|
|
4578
4592
|
}
|
|
@@ -4827,22 +4841,22 @@
|
|
|
4827
4841
|
static get styles() {
|
|
4828
4842
|
return i$3`
|
|
4829
4843
|
:host {
|
|
4830
|
-
---shadow-0: var(--shadow-0, ${r$
|
|
4831
|
-
---shadow-2: var(--shadow-2, ${r$
|
|
4832
|
-
---shadow-4: var(--shadow-4, ${r$
|
|
4833
|
-
---shadow-8: var(--shadow-8, ${r$
|
|
4834
|
-
|
|
4835
|
-
---color-background: var(--color-background, ${r$
|
|
4836
|
-
---color-border: var(--color-border, ${r$
|
|
4837
|
-
---color-text: var(--color-text, ${r$
|
|
4838
|
-
---color-text-inverse: var(--color-text-inverse, ${r$
|
|
4839
|
-
---color-link: var(--color-link, ${r$
|
|
4840
|
-
---color-element-background: var(--color-element-background, ${r$
|
|
4841
|
-
---color-element-disabled: var(--color-element-disabled, ${r$
|
|
4842
|
-
---color-element-enabled: var(--color-element-enabled, ${r$
|
|
4843
|
-
---color-element-selected: var(--color-element-selected, ${r$
|
|
4844
|
-
---color-element-border: var(--color-element-border, ${r$
|
|
4845
|
-
---color-element-emphasis: var(--color-element-emphasis, ${r$
|
|
4844
|
+
---shadow-0: var(--shadow-0, ${r$2(this.cssBoxShadow(0))});
|
|
4845
|
+
---shadow-2: var(--shadow-2, ${r$2(this.cssBoxShadow(2))});
|
|
4846
|
+
---shadow-4: var(--shadow-4, ${r$2(this.cssBoxShadow(4))});
|
|
4847
|
+
---shadow-8: var(--shadow-8, ${r$2(this.cssBoxShadow(8))});
|
|
4848
|
+
|
|
4849
|
+
---color-background: var(--color-background, ${r$2(this.greys.white)});
|
|
4850
|
+
---color-border: var(--color-border, ${r$2(this.greys.light75)});
|
|
4851
|
+
---color-text: var(--color-text, ${r$2(this.greys.dark75)});
|
|
4852
|
+
---color-text-inverse: var(--color-text-inverse, ${r$2(this.greys.white)});
|
|
4853
|
+
---color-link: var(--color-link, ${r$2(this.greys.dark25)});
|
|
4854
|
+
---color-element-background: var(--color-element-background, ${r$2(this.greys.light75)});
|
|
4855
|
+
---color-element-disabled: var(--color-element-disabled, ${r$2(this.greys.light50)});
|
|
4856
|
+
---color-element-enabled: var(--color-element-enabled, ${r$2(this.greys.dark25)});
|
|
4857
|
+
---color-element-selected: var(--color-element-selected, ${r$2(this.greys.grey)});
|
|
4858
|
+
---color-element-border: var(--color-element-border, ${r$2(this.greys.dark50)});
|
|
4859
|
+
---color-element-emphasis: var(--color-element-emphasis, ${r$2(this.greys.dark75)});
|
|
4846
4860
|
|
|
4847
4861
|
---font-family-base: var(--font-family-base, "Source Sans", sans-serif);
|
|
4848
4862
|
---font-family-math: var(--font-family-math, "Source Serif", serif);
|
|
@@ -4852,6 +4866,7 @@
|
|
|
4852
4866
|
---transition-duration: var(--transition-duration, 500ms);
|
|
4853
4867
|
|
|
4854
4868
|
font-family: var(---font-family-base);
|
|
4869
|
+
font-weight: normal;
|
|
4855
4870
|
}
|
|
4856
4871
|
|
|
4857
4872
|
:host,
|
|
@@ -4905,6 +4920,9 @@
|
|
|
4905
4920
|
static get styles() {
|
|
4906
4921
|
return [super.styles, i$3`
|
|
4907
4922
|
:host {
|
|
4923
|
+
---decidables-button-background-color-disabled: var(--decidables-button-background-color, var(---color-element-disabled));
|
|
4924
|
+
---decidables-button-background-color-enabled: var(--decidables-button-background-color, var(---color-element-enabled));
|
|
4925
|
+
|
|
4908
4926
|
margin: 0.25rem;
|
|
4909
4927
|
}
|
|
4910
4928
|
|
|
@@ -4924,7 +4942,7 @@
|
|
|
4924
4942
|
}
|
|
4925
4943
|
|
|
4926
4944
|
button:disabled {
|
|
4927
|
-
background-color: var(
|
|
4945
|
+
background-color: var(---decidables-button-background-color-disabled);
|
|
4928
4946
|
outline: none;
|
|
4929
4947
|
box-shadow: none;
|
|
4930
4948
|
}
|
|
@@ -4932,7 +4950,7 @@
|
|
|
4932
4950
|
button:enabled {
|
|
4933
4951
|
cursor: pointer;
|
|
4934
4952
|
|
|
4935
|
-
background-color: var(
|
|
4953
|
+
background-color: var(---decidables-button-background-color-enabled);
|
|
4936
4954
|
outline: none;
|
|
4937
4955
|
box-shadow: var(---shadow-2);
|
|
4938
4956
|
}
|
|
@@ -4983,6 +5001,11 @@
|
|
|
4983
5001
|
type: Boolean,
|
|
4984
5002
|
reflect: true
|
|
4985
5003
|
},
|
|
5004
|
+
scale: {
|
|
5005
|
+
attribute: 'scale',
|
|
5006
|
+
type: Boolean,
|
|
5007
|
+
reflect: true
|
|
5008
|
+
},
|
|
4986
5009
|
max: {
|
|
4987
5010
|
attribute: 'max',
|
|
4988
5011
|
type: Number,
|
|
@@ -5002,6 +5025,11 @@
|
|
|
5002
5025
|
attribute: 'value',
|
|
5003
5026
|
type: Number,
|
|
5004
5027
|
reflect: true
|
|
5028
|
+
},
|
|
5029
|
+
nonlinear: {
|
|
5030
|
+
attribute: false,
|
|
5031
|
+
type: Boolean,
|
|
5032
|
+
reflect: false
|
|
5005
5033
|
}
|
|
5006
5034
|
};
|
|
5007
5035
|
}
|
|
@@ -5010,13 +5038,30 @@
|
|
|
5010
5038
|
|
|
5011
5039
|
// Attributes
|
|
5012
5040
|
this.disabled = false;
|
|
5041
|
+
this.scale = false;
|
|
5013
5042
|
this.max = undefined;
|
|
5014
5043
|
this.min = undefined;
|
|
5015
5044
|
this.step = undefined;
|
|
5016
5045
|
this.value = undefined;
|
|
5017
|
-
|
|
5018
|
-
|
|
5019
|
-
|
|
5046
|
+
this.nonlinear = false;
|
|
5047
|
+
|
|
5048
|
+
// Properties
|
|
5049
|
+
this.rangeMax = undefined;
|
|
5050
|
+
this.rangeMin = undefined;
|
|
5051
|
+
this.rangeStep = undefined;
|
|
5052
|
+
this.rangeValue = undefined;
|
|
5053
|
+
|
|
5054
|
+
// Transform
|
|
5055
|
+
this.toRange = undefined;
|
|
5056
|
+
this.fromRange = undefined;
|
|
5057
|
+
}
|
|
5058
|
+
nonlinearRange(nonlinear, toRange, fromRange) {
|
|
5059
|
+
this.nonlinear = nonlinear;
|
|
5060
|
+
this.toRange = nonlinear ? toRange : undefined;
|
|
5061
|
+
this.fromRange = nonlinear ? fromRange : undefined;
|
|
5062
|
+
}
|
|
5063
|
+
rangeChanged(event) {
|
|
5064
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5020
5065
|
this.dispatchEvent(new CustomEvent('change', {
|
|
5021
5066
|
detail: {
|
|
5022
5067
|
value: this.value
|
|
@@ -5024,15 +5069,28 @@
|
|
|
5024
5069
|
bubbles: true
|
|
5025
5070
|
}));
|
|
5026
5071
|
}
|
|
5027
|
-
|
|
5072
|
+
rangeInputted(event) {
|
|
5073
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5074
|
+
}
|
|
5075
|
+
spinnerInputted(event) {
|
|
5028
5076
|
this.value = event.target.value;
|
|
5029
5077
|
}
|
|
5078
|
+
willUpdate() {
|
|
5079
|
+
this.rangeMax = this.max === undefined ? undefined : this.nonlinear ? this.toRange(this.max) : this.max;
|
|
5080
|
+
this.rangeMin = this.min === undefined ? undefined : this.nonlinear ? this.toRange(this.min) : this.min;
|
|
5081
|
+
this.rangeStep = this.step === undefined ? undefined : this.nonlinear ? 'any' : this.step;
|
|
5082
|
+
this.rangeValue = this.value === undefined ? undefined : this.nonlinear ? this.toRange(this.value) : this.value;
|
|
5083
|
+
}
|
|
5030
5084
|
static get styles() {
|
|
5031
5085
|
return [super.styles, i$3`
|
|
5032
5086
|
:host {
|
|
5033
|
-
---
|
|
5034
|
-
---
|
|
5035
|
-
---
|
|
5087
|
+
---decidables-slider-background-color: var(--decidables-slider-background-color, var(---color-element-disabled));
|
|
5088
|
+
---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
|
|
5089
|
+
---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
|
|
5090
|
+
|
|
5091
|
+
---shadow-2-rotate: var(--shadow-2-rotate, ${r$2(this.cssBoxShadow(2, true, false))});
|
|
5092
|
+
---shadow-4-rotate: var(--shadow-4-rotate, ${r$2(this.cssBoxShadow(4, true, false))});
|
|
5093
|
+
---shadow-8-rotate: var(--shadow-8-rotate, ${r$2(this.cssBoxShadow(8, true, false))});
|
|
5036
5094
|
|
|
5037
5095
|
display: flex;
|
|
5038
5096
|
|
|
@@ -5047,7 +5105,10 @@
|
|
|
5047
5105
|
}
|
|
5048
5106
|
|
|
5049
5107
|
.range {
|
|
5050
|
-
|
|
5108
|
+
position: relative;
|
|
5109
|
+
display: flex;
|
|
5110
|
+
|
|
5111
|
+
flex-direction: row;
|
|
5051
5112
|
|
|
5052
5113
|
width: 3.5rem;
|
|
5053
5114
|
height: 4.75rem;
|
|
@@ -5058,6 +5119,8 @@
|
|
|
5058
5119
|
--decidables-spinner-input-width: 3.5rem;
|
|
5059
5120
|
|
|
5060
5121
|
margin: 0 0.25rem 0.25rem;
|
|
5122
|
+
|
|
5123
|
+
background: var(---decidables-spinner-background-color);
|
|
5061
5124
|
}
|
|
5062
5125
|
|
|
5063
5126
|
/* Adapted from http://danielstern.ca/range.css/#/ */
|
|
@@ -5096,14 +5159,14 @@
|
|
|
5096
5159
|
width: 100%;
|
|
5097
5160
|
height: 4px;
|
|
5098
5161
|
|
|
5099
|
-
background: var(---
|
|
5162
|
+
background: var(---decidables-slider-background-color);
|
|
5100
5163
|
border: 0;
|
|
5101
5164
|
border-radius: 2px;
|
|
5102
5165
|
box-shadow: none;
|
|
5103
5166
|
}
|
|
5104
5167
|
|
|
5105
5168
|
input[type=range]:focus::-webkit-slider-runnable-track {
|
|
5106
|
-
background: var(---
|
|
5169
|
+
background: var(---decidables-slider-background-color);
|
|
5107
5170
|
}
|
|
5108
5171
|
|
|
5109
5172
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
@@ -5111,7 +5174,7 @@
|
|
|
5111
5174
|
width: 100%;
|
|
5112
5175
|
height: 4px;
|
|
5113
5176
|
|
|
5114
|
-
background: var(---
|
|
5177
|
+
background: var(---decidables-slider-background-color);
|
|
5115
5178
|
border: 0;
|
|
5116
5179
|
border-radius: 2px;
|
|
5117
5180
|
box-shadow: none;
|
|
@@ -5131,7 +5194,7 @@
|
|
|
5131
5194
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5132
5195
|
input[type=range]::-ms-fill-lower {
|
|
5133
5196
|
background: #cccccc;
|
|
5134
|
-
/* background: var(---
|
|
5197
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5135
5198
|
border: 0;
|
|
5136
5199
|
border-radius: 2px;
|
|
5137
5200
|
box-shadow: none;
|
|
@@ -5140,7 +5203,7 @@
|
|
|
5140
5203
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5141
5204
|
input[type=range]::-ms-fill-upper {
|
|
5142
5205
|
background: #cccccc;
|
|
5143
|
-
/* background: var(---
|
|
5206
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5144
5207
|
border: 0;
|
|
5145
5208
|
border-radius: 2px;
|
|
5146
5209
|
box-shadow: none;
|
|
@@ -5148,12 +5211,12 @@
|
|
|
5148
5211
|
|
|
5149
5212
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5150
5213
|
input[type=range]:focus::-ms-fill-lower {
|
|
5151
|
-
background: var(---
|
|
5214
|
+
background: var(---decidables-slider-background-color);
|
|
5152
5215
|
}
|
|
5153
5216
|
|
|
5154
5217
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5155
5218
|
input[type=range]:focus::-ms-fill-upper {
|
|
5156
|
-
background: var(---
|
|
5219
|
+
background: var(---decidables-slider-background-color);
|
|
5157
5220
|
}
|
|
5158
5221
|
|
|
5159
5222
|
/* Thumb */
|
|
@@ -5171,12 +5234,12 @@
|
|
|
5171
5234
|
}
|
|
5172
5235
|
|
|
5173
5236
|
input[type=range]:disabled::-webkit-slider-thumb {
|
|
5174
|
-
background: var(---
|
|
5237
|
+
background: var(---decidables-slider-background-color);
|
|
5175
5238
|
box-shadow: none;
|
|
5176
5239
|
}
|
|
5177
5240
|
|
|
5178
5241
|
input[type=range]:enabled::-webkit-slider-thumb {
|
|
5179
|
-
background: var(---
|
|
5242
|
+
background: var(---decidables-slider-color);
|
|
5180
5243
|
box-shadow: var(---shadow-2-rotate);
|
|
5181
5244
|
}
|
|
5182
5245
|
|
|
@@ -5207,13 +5270,13 @@
|
|
|
5207
5270
|
|
|
5208
5271
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5209
5272
|
input[type=range]:disabled::-moz-range-thumb {
|
|
5210
|
-
background: var(---
|
|
5273
|
+
background: var(---decidables-slider-background-color);
|
|
5211
5274
|
box-shadow: none;
|
|
5212
5275
|
}
|
|
5213
5276
|
|
|
5214
5277
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5215
5278
|
input[type=range]:enabled::-moz-range-thumb {
|
|
5216
|
-
background: var(---
|
|
5279
|
+
background: var(---decidables-slider-color);
|
|
5217
5280
|
box-shadow: var(---shadow-2-rotate);
|
|
5218
5281
|
}
|
|
5219
5282
|
|
|
@@ -5250,13 +5313,13 @@
|
|
|
5250
5313
|
|
|
5251
5314
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5252
5315
|
input[type=range]:disabled::-ms-thumb {
|
|
5253
|
-
background: var(---
|
|
5316
|
+
background: var(---decidables-slider-background-color);
|
|
5254
5317
|
box-shadow: none;
|
|
5255
5318
|
}
|
|
5256
5319
|
|
|
5257
5320
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5258
5321
|
input[type=range]:enabled::-ms-thumb {
|
|
5259
|
-
background: var(---
|
|
5322
|
+
background: var(---decidables-slider-color);
|
|
5260
5323
|
box-shadow: var(---shadow-2-rotate);
|
|
5261
5324
|
}
|
|
5262
5325
|
|
|
@@ -5278,6 +5341,33 @@
|
|
|
5278
5341
|
:host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {
|
|
5279
5342
|
box-shadow: var(---shadow-8-rotate);
|
|
5280
5343
|
}
|
|
5344
|
+
|
|
5345
|
+
datalist {
|
|
5346
|
+
position: absolute;
|
|
5347
|
+
left: 2rem;
|
|
5348
|
+
z-index: -1;
|
|
5349
|
+
display: flex;
|
|
5350
|
+
|
|
5351
|
+
flex-direction: column;
|
|
5352
|
+
|
|
5353
|
+
align-items: flex-start;
|
|
5354
|
+
justify-content: space-between;
|
|
5355
|
+
|
|
5356
|
+
height: 4.75rem;
|
|
5357
|
+
|
|
5358
|
+
font-size: 0.75rem;
|
|
5359
|
+
}
|
|
5360
|
+
|
|
5361
|
+
option {
|
|
5362
|
+
padding: 0;
|
|
5363
|
+
|
|
5364
|
+
line-height: 0.8;
|
|
5365
|
+
min-block-size: 0;
|
|
5366
|
+
}
|
|
5367
|
+
|
|
5368
|
+
option::before {
|
|
5369
|
+
content: "– ";
|
|
5370
|
+
}
|
|
5281
5371
|
`];
|
|
5282
5372
|
}
|
|
5283
5373
|
render() {
|
|
@@ -5286,9 +5376,15 @@
|
|
|
5286
5376
|
<slot></slot>
|
|
5287
5377
|
</label>
|
|
5288
5378
|
<div class="range">
|
|
5289
|
-
<input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.
|
|
5379
|
+
<input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.rangeMin)} max=${o(this.rangeMax)} step=${o(this.rangeStep)} .value=${this.rangeValue} @change=${this.rangeChanged.bind(this)} @input=${this.rangeInputted.bind(this)}>
|
|
5380
|
+
${this.scale ? x$1`
|
|
5381
|
+
<datalist id="ticks">
|
|
5382
|
+
<option value=${o(this.rangeMax)} label=${o(this.max)}></option>
|
|
5383
|
+
<option value=${o(this.rangeMin)} label=${o(this.min)}></option>
|
|
5384
|
+
</datalist>
|
|
5385
|
+
` : x$1``}
|
|
5290
5386
|
</div>
|
|
5291
|
-
<decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.
|
|
5387
|
+
<decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.spinnerInputted.bind(this)}></decidables-spinner>
|
|
5292
5388
|
`;
|
|
5293
5389
|
}
|
|
5294
5390
|
}
|
|
@@ -5497,7 +5593,6 @@
|
|
|
5497
5593
|
padding: 0;
|
|
5498
5594
|
margin: -1px;
|
|
5499
5595
|
overflow: hidden;
|
|
5500
|
-
clip: rect(0 0 0 0);
|
|
5501
5596
|
|
|
5502
5597
|
white-space: nowrap;
|
|
5503
5598
|
|
|
@@ -5719,7 +5814,6 @@
|
|
|
5719
5814
|
padding: 0;
|
|
5720
5815
|
margin: -1px;
|
|
5721
5816
|
overflow: hidden;
|
|
5722
|
-
clip: rect(0 0 0 0);
|
|
5723
5817
|
|
|
5724
5818
|
white-space: nowrap;
|
|
5725
5819
|
|
|
@@ -5902,17 +5996,17 @@
|
|
|
5902
5996
|
return [super.styles, i$3`
|
|
5903
5997
|
:host {
|
|
5904
5998
|
/* Declare base colors */
|
|
5905
|
-
${r$
|
|
5999
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5906
6000
|
return `---color-${color}: var(--color-${color}, ${this.colors[color]});`;
|
|
5907
6001
|
}).join('\n'))}
|
|
5908
6002
|
|
|
5909
6003
|
/* Declare light colors */
|
|
5910
|
-
${r$
|
|
6004
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5911
6005
|
return `---color-${color}-light: var(--color-${color}-light, ${this.lights[color]});`;
|
|
5912
6006
|
}).join('\n'))}
|
|
5913
6007
|
|
|
5914
6008
|
/* Declare dark colors */
|
|
5915
|
-
${r$
|
|
6009
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5916
6010
|
return `---color-${color}-dark: var(--color-${color}-dark, ${this.darks[color]});`;
|
|
5917
6011
|
}).join('\n'))}
|
|
5918
6012
|
}
|
|
@@ -6089,15 +6183,15 @@
|
|
|
6089
6183
|
render() {
|
|
6090
6184
|
return x$1`
|
|
6091
6185
|
<div class="holder">
|
|
6092
|
-
${this.trials ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
|
|
6186
|
+
${this.trials != null ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
|
|
6093
6187
|
${this.resample ? x$1`
|
|
6094
6188
|
<div class="buttons">
|
|
6095
6189
|
${this.resample ? x$1`<decidables-button name="resample" @click=${this.doResample.bind(this)}>Resample</decidables-button>` : x$1``}
|
|
6096
6190
|
</div>
|
|
6097
6191
|
` : x$1``}
|
|
6098
|
-
${this.duration ? x$1`<decidables-slider class="duration" min="10" max="2000" step="10" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>` : x$1``}
|
|
6099
|
-
${this.coherence ? x$1`<decidables-slider class="coherence" min="0" max="1" step=".01" .value=${this.coherence} @change=${this.setCoherence.bind(this)} @input=${this.setCoherence.bind(this)}>Coherence</decidables-slider>` : x$1``}
|
|
6100
|
-
${this.color
|
|
6192
|
+
${this.duration != null ? x$1`<decidables-slider class="duration" min="10" max="2000" step="10" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>` : x$1``}
|
|
6193
|
+
${this.coherence != null ? x$1`<decidables-slider class="coherence" min="0" max="1" step=".01" .value=${this.coherence} @change=${this.setCoherence.bind(this)} @input=${this.setCoherence.bind(this)}>Coherence</decidables-slider>` : x$1``}
|
|
6194
|
+
${this.color != null ? x$1`
|
|
6101
6195
|
<decidables-toggle class="color" @change=${this.chooseColor.bind(this)}>
|
|
6102
6196
|
<span slot="label">Emphasis</span>
|
|
6103
6197
|
<decidables-toggle-option name="toggle" value="none" ?checked=${this.color === 'none'}>None</decidables-toggle-option>
|
|
@@ -6122,13 +6216,13 @@
|
|
|
6122
6216
|
DDMMath Static Class - Not intended for instantiation!
|
|
6123
6217
|
|
|
6124
6218
|
Model parameters:
|
|
6125
|
-
a = boundary separation
|
|
6126
|
-
z = starting point as a proportion of a
|
|
6127
|
-
v = drift rate (per second)
|
|
6128
|
-
t0 = non-decision time (in milliseconds)
|
|
6129
|
-
s = within-trial variability in drift rate (s^2 = infinitesimal variance)
|
|
6219
|
+
a = boundary separation [0, Infinity)
|
|
6220
|
+
z = starting point as a proportion of a (0, 1)
|
|
6221
|
+
v = drift rate (per second) (-Infinity, Infinity)
|
|
6222
|
+
t0 = non-decision time (in milliseconds) (0, Infinity)
|
|
6223
|
+
s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)
|
|
6130
6224
|
|
|
6131
|
-
zPrime = starting point on a 0-to-a scale (typically used in published equations)
|
|
6225
|
+
zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)
|
|
6132
6226
|
|
|
6133
6227
|
Behavioral variables:
|
|
6134
6228
|
pE = proportion of error trials
|
|
@@ -6148,7 +6242,37 @@
|
|
|
6148
6242
|
EZ-diffusion model (Wagenmakers et al., 2007)
|
|
6149
6243
|
*/
|
|
6150
6244
|
class DDMMath {
|
|
6151
|
-
static s =
|
|
6245
|
+
static s = {
|
|
6246
|
+
DEFAULT: 1
|
|
6247
|
+
};
|
|
6248
|
+
static a = {
|
|
6249
|
+
DEFAULT: 1.2,
|
|
6250
|
+
MIN: 0.01,
|
|
6251
|
+
MAX: 2.0,
|
|
6252
|
+
STEP: 0.01,
|
|
6253
|
+
JUMP: 0.1
|
|
6254
|
+
};
|
|
6255
|
+
static z = {
|
|
6256
|
+
DEFAULT: 0.55,
|
|
6257
|
+
MIN: 0.01,
|
|
6258
|
+
MAX: 0.99,
|
|
6259
|
+
STEP: 0.01,
|
|
6260
|
+
JUMP: 0.1
|
|
6261
|
+
};
|
|
6262
|
+
static v = {
|
|
6263
|
+
DEFAULT: 1.5,
|
|
6264
|
+
MIN: 0.01,
|
|
6265
|
+
MAX: 5.0,
|
|
6266
|
+
STEP: 0.01,
|
|
6267
|
+
JUMP: 0.1
|
|
6268
|
+
};
|
|
6269
|
+
static t0 = {
|
|
6270
|
+
DEFAULT: 150,
|
|
6271
|
+
MIN: 0,
|
|
6272
|
+
MAX: 500,
|
|
6273
|
+
STEP: 1,
|
|
6274
|
+
JUMP: 10
|
|
6275
|
+
};
|
|
6152
6276
|
|
|
6153
6277
|
// Calculate a bunch of statistics for an array of trials
|
|
6154
6278
|
static trials2stats(trials) {
|
|
@@ -6216,7 +6340,7 @@
|
|
|
6216
6340
|
}
|
|
6217
6341
|
|
|
6218
6342
|
// Probability of an Error Response
|
|
6219
|
-
static azv2pE(a, z, v, s = DDMMath.s) {
|
|
6343
|
+
static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6220
6344
|
const zPrime = a * z;
|
|
6221
6345
|
const A = Math.exp(-2 * v * a / s ** 2);
|
|
6222
6346
|
const Z = Math.exp(-2 * v * zPrime / s ** 2);
|
|
@@ -6224,13 +6348,13 @@
|
|
|
6224
6348
|
}
|
|
6225
6349
|
|
|
6226
6350
|
// Probability of a Correct Response
|
|
6227
|
-
static azv2pC(a, z, v, s = DDMMath.s) {
|
|
6351
|
+
static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6228
6352
|
return DDMMath.azv2pE(a, 1 - z, -v, s);
|
|
6229
6353
|
}
|
|
6230
6354
|
|
|
6231
6355
|
// Mean Overall RT
|
|
6232
6356
|
// Equation 5 (Grasman et al., 2009)
|
|
6233
|
-
static azvt02m(a, z, v, t0, s = DDMMath.s) {
|
|
6357
|
+
static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6234
6358
|
const zPrime = a * z;
|
|
6235
6359
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6236
6360
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6240,7 +6364,7 @@
|
|
|
6240
6364
|
|
|
6241
6365
|
// SD Overall RT
|
|
6242
6366
|
// Equation 6 (Grasman et al., 2009)
|
|
6243
|
-
static azv2sd(a, z, v, s = DDMMath.s) {
|
|
6367
|
+
static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6244
6368
|
const zPrime = a * z;
|
|
6245
6369
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6246
6370
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6250,7 +6374,7 @@
|
|
|
6250
6374
|
|
|
6251
6375
|
// Mean Error RT
|
|
6252
6376
|
// Equation 13 (Grasman et al., 2009)
|
|
6253
|
-
static azvt02mE(a, z, v, t0, s = DDMMath.s) {
|
|
6377
|
+
static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6254
6378
|
function phi(x, y) {
|
|
6255
6379
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6256
6380
|
}
|
|
@@ -6261,7 +6385,7 @@
|
|
|
6261
6385
|
|
|
6262
6386
|
// SD Error RT
|
|
6263
6387
|
// Equation 14 (Grasman et al., 2009)
|
|
6264
|
-
static azv2sdE(a, z, v, s = DDMMath.s) {
|
|
6388
|
+
static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6265
6389
|
function phi(x, y) {
|
|
6266
6390
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6267
6391
|
}
|
|
@@ -6271,17 +6395,17 @@
|
|
|
6271
6395
|
}
|
|
6272
6396
|
|
|
6273
6397
|
// Mean Correct RT
|
|
6274
|
-
static azvt02mC(a, z, v, t0, s = DDMMath.s) {
|
|
6398
|
+
static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6275
6399
|
return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
|
|
6276
6400
|
}
|
|
6277
6401
|
|
|
6278
6402
|
// SD Correct RT
|
|
6279
|
-
static azv2sdC(a, z, v, s = DDMMath.s) {
|
|
6403
|
+
static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6280
6404
|
return DDMMath.azv2sdE(a, 1 - z, -v, s);
|
|
6281
6405
|
}
|
|
6282
6406
|
|
|
6283
6407
|
// Density of Error RT
|
|
6284
|
-
static tazv2gE(t, a, z, v, s = DDMMath.s) {
|
|
6408
|
+
static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6285
6409
|
if (!t) return 0;
|
|
6286
6410
|
const zPrime = a * z;
|
|
6287
6411
|
const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
|
|
@@ -6298,7 +6422,7 @@
|
|
|
6298
6422
|
}
|
|
6299
6423
|
|
|
6300
6424
|
// Density of Correct RT
|
|
6301
|
-
static tazv2gC(t, a, z, v, s = DDMMath.s) {
|
|
6425
|
+
static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6302
6426
|
return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
|
|
6303
6427
|
}
|
|
6304
6428
|
|
|
@@ -6433,10 +6557,7 @@
|
|
|
6433
6557
|
this.startTime = undefined; // Start time of current trial
|
|
6434
6558
|
this.rt = undefined; // RT for current trial
|
|
6435
6559
|
|
|
6436
|
-
this.
|
|
6437
|
-
this.errorCount = 0; // Count of Error Trials
|
|
6438
|
-
this.nrCount = 0; // Count of No Response trials
|
|
6439
|
-
|
|
6560
|
+
this.data = {};
|
|
6440
6561
|
this.trials = []; // Record of trials in block
|
|
6441
6562
|
this.alignState();
|
|
6442
6563
|
}
|
|
@@ -6453,11 +6574,10 @@
|
|
|
6453
6574
|
}
|
|
6454
6575
|
}
|
|
6455
6576
|
get totalPayoff() {
|
|
6456
|
-
return this.correctCount * this.correctPayoff + this.errorCount * this.errorPayoff + this.nrCount * this.nrPayoff;
|
|
6577
|
+
return this.data.correctCount * this.correctPayoff + this.data.errorCount * this.errorPayoff + this.data.nrCount * this.nrPayoff;
|
|
6457
6578
|
}
|
|
6458
6579
|
alignState() {
|
|
6459
|
-
|
|
6460
|
-
Object.assign(this, stats);
|
|
6580
|
+
this.data = DDMMath.trials2stats(this.trials);
|
|
6461
6581
|
}
|
|
6462
6582
|
start(signal, trial) {
|
|
6463
6583
|
this.startTime = Date.now();
|
|
@@ -6472,7 +6592,6 @@
|
|
|
6472
6592
|
this.state = 'feedback';
|
|
6473
6593
|
if (this.response === undefined) {
|
|
6474
6594
|
this.outcome = 'nr';
|
|
6475
|
-
this.nrCount += 1;
|
|
6476
6595
|
this.rt = undefined;
|
|
6477
6596
|
this.trials.push({
|
|
6478
6597
|
trial: this.trialCount,
|
|
@@ -6497,10 +6616,8 @@
|
|
|
6497
6616
|
this.response = response;
|
|
6498
6617
|
if (this.signal === this.response) {
|
|
6499
6618
|
this.outcome = 'correct';
|
|
6500
|
-
this.correctCount += 1;
|
|
6501
6619
|
} else if (this.signal !== this.response) {
|
|
6502
6620
|
this.outcome = 'error';
|
|
6503
|
-
this.errorCount += 1;
|
|
6504
6621
|
}
|
|
6505
6622
|
this.trials.push({
|
|
6506
6623
|
trial: this.trialCount,
|
|
@@ -6519,16 +6636,7 @@
|
|
|
6519
6636
|
response: this.response,
|
|
6520
6637
|
outcome: this.outcome,
|
|
6521
6638
|
payoff: this.trialPayoff,
|
|
6522
|
-
|
|
6523
|
-
errorCount: this.errorCount,
|
|
6524
|
-
nrCount: this.nrCount,
|
|
6525
|
-
accuracy: this.accuracy,
|
|
6526
|
-
meanRT: this.meanRT,
|
|
6527
|
-
correctMeanRT: this.correctMeanRT,
|
|
6528
|
-
errorMeanRT: this.errorMeanRT,
|
|
6529
|
-
sdRT: this.sdRT,
|
|
6530
|
-
correctSDRT: this.correctSDRT,
|
|
6531
|
-
errorSDRT: this.errorSDRT,
|
|
6639
|
+
data: this.data,
|
|
6532
6640
|
totalPayoff: this.totalPayoff
|
|
6533
6641
|
},
|
|
6534
6642
|
bubbles: true
|
|
@@ -6541,9 +6649,6 @@
|
|
|
6541
6649
|
this.signal = undefined;
|
|
6542
6650
|
this.response = undefined;
|
|
6543
6651
|
this.outcome = undefined;
|
|
6544
|
-
this.correctCount = 0;
|
|
6545
|
-
this.errorCount = 0;
|
|
6546
|
-
this.nrCount = 0;
|
|
6547
6652
|
this.trials = [];
|
|
6548
6653
|
this.alignState();
|
|
6549
6654
|
}
|
|
@@ -7234,7 +7339,7 @@
|
|
|
7234
7339
|
};
|
|
7235
7340
|
}
|
|
7236
7341
|
|
|
7237
|
-
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

    Model parameters:
      a = boundary separation
      z = starting point as a proportion of a
      v = drift rate (per second)
      t0 = non-decision time (in milliseconds)
      s = within-trial variability in drift rate (s^2 = infinitesimal variance)

      zPrime = starting point on a 0-to-a scale (typically used in published equations)

    Behavioral variables:
      pE = proportion of error trials
      pC = proportion of correct trials
      m = mean of overall RTs (in milliseconds)
      mE = mean of error RTs (in milliseconds)
      mC = mean correct RTs (in milliseconds)
      sd = standard deviation of overall RTs (in milliseconds)
      sdE = standard deviation of error RTs (in milliseconds)
      sdC = standard deviation of correct RTs (in milliseconds)

    Equations:
      Probability of correct and error responses (Alexandrowicz, 2020)
      Mean of overall, error, and correct RTs (Grasman et al., 2009)
      Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)
      Density of error and correct RT distributions (Alexandrowicz, 2020)
      EZ-diffusion model (Wagenmakers et al., 2007)
  */
  class DDMMath {
    static s = 1;

    // Calculate a bunch of statistics for an array of trials
    static trials2stats(trials) {
      const stats = {};

      // First-order sums
      const sums = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.correctCount += 1;
            accumulator.correctRTSum += trial.rt;
            break;
          case 'error':
            accumulator.errorCount += 1;
            accumulator.errorRTSum += trial.rt;
            break;
          case 'nr':
            accumulator.nrCount += 1;
            break;
          // No-op
        }
        return accumulator;
      }, {
        correctCount: 0,
        errorCount: 0,
        nrCount: 0,
        correctRTSum: 0,
        errorRTSum: 0
      });

      // First-order stats
      stats.correctCount = sums.correctCount;
      stats.errorCount = sums.errorCount;
      stats.nrCount = sums.nrCount;
      stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);
      stats.correctMeanRT = sums.correctRTSum / sums.correctCount;
      stats.errorMeanRT = sums.errorRTSum / sums.errorCount;
      stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);

      // Second-order sums
      const sums2 = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;
            break;
          case 'error':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;
            break;
          // No-op
        }
        return accumulator;
      }, {
        ss: 0,
        correctSS: 0,
        errorSS: 0
      });

      // Second-order stats
      stats.correctSDRT = stats.correctCount > 1 ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1)) : NaN;
      stats.errorSDRT = stats.errorCount > 1 ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1)) : NaN;
      stats.sdRT = stats.correctCount + stats.errorCount > 1 ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1)) : NaN;
      return stats;
    }

    // Probability of an Error Response
    static azv2pE(a, z, v, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2);
      const Z = Math.exp(-2 * v * zPrime / s ** 2);
      return (A - Z) / (A - 1);
    }

    // Probability of a Correct Response
    static azv2pC(a, z, v, s = DDMMath.s) {
      return DDMMath.azv2pE(a, 1 - z, -v, s);
    }

    // Mean Overall RT
    // Equation 5 (Grasman et al., 2009)
    static azvt02m(a, z, v, t0, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const mean = -(zPrime / v) + a / v * (Z / A);
      return t0 + mean * 1000;
    }

    // SD Overall RT
    // Equation 6 (Grasman et al., 2009)
    static azv2sd(a, z, v, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const variance = (-v * a ** 2 * (Z + 4) * Z / A ** 2 + ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A - s ** 2 * zPrime) / v ** 3;
      return Math.sqrt(variance) * 1000;
    }

    // Mean Error RT
    // Equation 13 (Grasman et al., 2009)
    static azvt02mE(a, z, v, t0, s = DDMMath.s) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0)) / (v * phi(zPrime, a) * phi(-a, 0));
      return t0 + mean * 1000;
    }

    // SD Error RT
    // Equation 14 (Grasman et al., 2009)
    static azv2sdE(a, z, v, s = DDMMath.s) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const variance = -2 * a * phi(0, zPrime) * (2 * v * a * phi(zPrime, 2 * a) + s ** 2 * phi(0, a) * phi(zPrime, a)) * Math.exp(2 * v * a / s ** 2) / (v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2) + (4 * v * zPrime * (2 * a - zPrime) * Math.exp(2 * v * (zPrime + a) / s ** 2) + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)) / (v ** 3 * phi(zPrime, a) ** 2);
      return Math.sqrt(variance) * 1000;
    }

    // Mean Correct RT
    static azvt02mC(a, z, v, t0, s = DDMMath.s) {
      return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
    }

    // SD Correct RT
    static azv2sdC(a, z, v, s = DDMMath.s) {
      return DDMMath.azv2sdE(a, 1 - z, -v, s);
    }

    // Density of Error RT
    static tazv2gE(t, a, z, v, s = DDMMath.s) {
      if (!t) return 0;
      const zPrime = a * z;
      const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
      let k = 0;
      let term = 0;
      let sum = 0;
      do {
        k += 1;
        term = k * Math.sin(Math.PI * zPrime * k / a) * Math.exp(-0.5 * (v ** 2 / s ** 2 + Math.PI ** 2 * k ** 2 * s ** 2 / a ** 2) * t);
        sum += term;
      } while (k < 200); // ?? HACK

      return base * sum;
    }

    // Density of Correct RT
    static tazv2gC(t, a, z, v, s = DDMMath.s) {
      return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
    }

    // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html
    // EZ-function for starting values
    // input: obj - Object with properties
    //    pC - Proportion correct
    //    sd - sample standard deviation of the RT's in ms
    //    m - sample mean of the RT's in ms
    //    s - diffusion standard deviation
    // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters
    static data2ez({
      accuracy: pC,
      sdRT: sd,
      meanRT: m,
      s
    }) {
      function sign(r) {
        return r > 0 ? 1 : r === 0 ? 0 : -1;
      }
      function logit(p) {
        return Math.log(p / (1 - p));
      }
      const vrt = (sd / 1000) ** 2;
      const mrt = m / 1000;
      const s2 = s ** 2;
      const l = logit(pC);
      const x = l * (l * pC ** 2 - l * pC + pC - 0.5) / vrt;
      const v = sign(pC - 0.5) * s * x ** (1 / 4);
      const a = s2 * logit(pC) / v;
      const y = -v * a / s2;
      const mdt = a / (2 * v) * (1 - Math.exp(y)) / (1 + Math.exp(y));
      const t0 = mrt ? mrt - mdt : null; // compute Ter only if MRT was provided

      const t0Prime = t0 * 1000;
      return {
        v,
        a,
        t0: t0Prime,
        s
      };
    }
    static data2ez2() {
      throw new Error('data2ez2 is not implemented!');
    }
  }

  // Internal dependencies

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

  self.onmessage = event => {
    const params = DDMMath.data2ez({
      ...event.data,
      s: DDMMath.s
    });

    // ##### Arbitrary default values!!!
    const a = !isNaN(params.a) ? params.a : 1.5;
    const z = !isNaN(params.z) ? params.z : 0.5;
    const v = !isNaN(params.v) ? params.v : 0.1;
    const t0 = !isNaN(params.t0) ? params.t0 : 100;
    const s = !isNaN(params.s) ? params.s : DDMMath.s;
    const predicted = {
      accuracy: DDMMath.azv2pC(a, z, v),
      correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),
      errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),
      meanRT: DDMMath.azvt02m(a, z, v, t0),
      correctSDRT: DDMMath.azv2sdC(a, z, v),
      errorSDRT: DDMMath.azv2sdE(a, z, v),
      sdRT: DDMMath.azv2sd(a, z, v)
    };
    self.postMessage({
      params: {
        a,
        z,
        v,
        t0,
        s
      },
      predicted
    });
  };

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

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation\n    z = starting point as a proportion of a\n    v = drift rate (per second)\n    t0 = non-decision time (in milliseconds)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = 1;\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","a","z","v","zPrime","A","exp","Z","azv2pC","azvt02m","t0","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":";;;EACA;EACA;;EAEA;EACA;EACA;EACA;EACA;EACA;;EAEA;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACe,MAAMA,OAAO,CAAC;IAC3B,OAAOC,CAAC,GAAG,CAAC;;EAEZ;IACA,OAAOC,YAAYA,CAACC,MAAM,EAAE;MAC1B,MAAMC,KAAK,GAAG,EAAE;;EAEhB;MACA,MAAMC,IAAI,GAAGF,MAAM,CAACG,MAAM,CACxB,CAACC,WAAW,EAAEC,KAAK,KAAK;QACtB,QAAQA,KAAK,CAACC,OAAO;EACnB,QAAA,KAAK,SAAS;YACZF,WAAW,CAACG,YAAY,IAAI,CAAC;EAC7BH,UAAAA,WAAW,CAACI,YAAY,IAAIH,KAAK,CAACI,EAAE;EACpC,UAAA;EACF,QAAA,KAAK,OAAO;YACVL,WAAW,CAACM,UAAU,IAAI,CAAC;EAC3BN,UAAAA,WAAW,CAACO,UAAU,IAAIN,KAAK,CAACI,EAAE;EAClC,UAAA;EACF,QAAA,KAAK,IAAI;YACPL,WAAW,CAACQ,OAAO,IAAI,CAAC;EACxB,UAAA;EAEA;EACJ;EACA,MAAA,OAAOR,WAAW;EACpB,KAAC,EACD;EACEG,MAAAA,YAAY,EAAE,CAAC;EACfG,MAAAA,UAAU,EAAE,CAAC;EACbE,MAAAA,OAAO,EAAE,CAAC;EAEVJ,MAAAA,YAAY,EAAE,CAAC;EACfG,MAAAA,UAAU,EAAE;EACd,KACF,CAAC;;EAED;EACAV,IAAAA,KAAK,CAACM,YAAY,GAAGL,IAAI,CAACK,YAAY;EACtCN,IAAAA,KAAK,CAACS,UAAU,GAAGR,IAAI,CAACQ,UAAU;EAClCT,IAAAA,KAAK,CAACW,OAAO,GAAGV,IAAI,CAACU,OAAO;EAC5BX,IAAAA,KAAK,CAACY,QAAQ,GAAGX,IAAI,CAACK,YAAY,IAAIL,IAAI,CAACK,YAAY,GAAGL,IAAI,CAACQ,UAAU,GAAGR,IAAI,CAACU,OAAO,CAAC;MAEzFX,KAAK,CAACa,aAAa,GAAGZ,IAAI,CAACM,YAAY,GAAGN,IAAI,CAACK,YAAY;MAC3DN,KAAK,CAACc,WAAW,GAAGb,IAAI,CAACS,UAAU,GAAGT,IAAI,CAACQ,UAAU;EACrDT,IAAAA,KAAK,CAACe,MAAM,GAAG,CAACd,IAAI,CAACM,YAAY,GAAGN,IAAI,CAACS,UAAU,KAAKT,IAAI,CAACK,YAAY,GAAGL,IAAI,CAACQ,UAAU,CAAC;;EAE5F;MACA,MAAMO,KAAK,GAAGjB,MAAM,CAACG,MAAM,CACzB,CAACC,WAAW,EAAEC,KAAK,KAAK;QACtB,QAAQA,KAAK,CAACC,OAAO;EACnB,QAAA,KAAK,SAAS;EACZF,UAAAA,WAAW,CAACc,EAAE,IAAI,CAACb,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACe,MAAM,KAAK,CAAC;EAChDZ,UAAAA,WAAW,CAACe,SAAS,IAAI,CAACd,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACa,aAAa,KAAK,CAAC;EAC9D,UAAA;EACF,QAAA,KAAK,OAAO;EACVV,UAAAA,WAAW,CAACc,EAAE,IAAI,CAACb,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACe,MAAM,KAAK,CAAC;EAChDZ,UAAAA,WAAW,CAACgB,OAAO,IAAI,CAACf,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACc,WAAW,KAAK,CAAC;EAC1D,UAAA;EAEA;EACJ;EACA,MAAA,OAAOX,WAAW;EACpB,KAAC,EACD;EACEc,MAAAA,EAAE,EAAE,CAAC;EACLC,MAAAA,SAAS,EAAE,CAAC;EACZC,MAAAA,OAAO,EAAE;EACX,KACF,CAAC;;EAED;MACAnB,KAAK,CAACoB,WAAW,GAAIpB,KAAK,CAACM,YAAY,GAAG,CAAC,GACvCe,IAAI,CAACC,IAAI,CAACN,KAAK,CAACE,SAAS,IAAIlB,KAAK,CAACM,YAAY,GAAG,CAAC,CAAC,CAAC,GACrDiB,GAAG;MACPvB,KAAK,CAACwB,SAAS,GAAIxB,KAAK,CAACS,UAAU,GAAG,CAAC,GACnCY,IAAI,CAACC,IAAI,CAACN,KAAK,CAACG,OAAO,IAAInB,KAAK,CAACS,UAAU,GAAG,CAAC,CAAC,CAAC,GACjDc,GAAG;EACPvB,IAAAA,KAAK,CAACyB,IAAI,GAAIzB,KAAK,CAACM,YAAY,GAAGN,KAAK,CAACS,UAAU,GAAG,CAAC,GACnDY,IAAI,CAACC,IAAI,CAACN,KAAK,CAACC,EAAE,IAAIjB,KAAK,CAACM,YAAY,GAAGN,KAAK,CAACS,UAAU,GAAG,CAAC,CAAC,CAAC,GACjEc,GAAG;EAEP,IAAA,OAAOvB,KAAK;EACd;;EAEA;EACA,EAAA,OAAO0B,MAAMA,CAACC,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACpC,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC;EAEpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC;EACzC,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC;MAE9C,OAAO,CAACkC,CAAC,GAAGE,CAAC,KAAKF,CAAC,GAAG,CAAC,CAAC;EAC1B;;EAEA;EACA,EAAA,OAAOG,MAAMA,CAACP,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACpC,IAAA,OAAOD,OAAO,CAAC8B,MAAM,CAACC,CAAC,EAAE,CAAC,GAAGC,CAAC,EAAE,CAACC,CAAC,EAAEhC,CAAC,CAAC;EACxC;;EAEA;EACA;EACA,EAAA,OAAOsC,OAAOA,CAACR,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,EAAEvC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACzC,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC;EACpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC;EAC7C,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC;EAElD,IAAA,MAAMwC,IAAI,GAAG,EAAEP,MAAM,GAAGD,CAAC,CAAC,GAAIF,CAAC,GAAGE,CAAC,IAAKI,CAAC,GAAGF,CAAC,CAAC;EAC9C,IAAA,OAAOK,EAAE,GAAGC,IAAI,GAAG,IAAI;EACzB;;EAEA;EACA;EACA,EAAA,OAAOC,MAAMA,CAACX,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACpC,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC;EACpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC;EAC7C,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,EAAE,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC;EAElD,IAAA,MAAM0C,QAAQ,GAAG,CAEZ,CAACV,CAAC,GAAGF,CAAC,IAAI,CAAC,IAAIM,CAAC,GAAG,CAAC,CAAC,GAAGA,CAAC,GAAIF,CAAC,IAAI,CAAC,GAEpC,CAAC,CAAC,EAAE,GAAGF,CAAC,GAAGF,CAAC,IAAI,CAAC,GAAG,CAAC,GAAGE,CAAC,GAAGC,MAAM,GAAGH,CAAC,GAAG9B,CAAC,IAAI,CAAC,GAAG8B,CAAC,IAAIM,CAAC,GAAG,CAAC,GAAGJ,CAAC,GAAGC,MAAM,GAAGH,CAAC,IAAII,CAClF,GACClC,CAAC,IAAI,CAAC,GAAGiC,MACV,IACCD,CAAC,IAAI,CAAC;EAEV,IAAA,OAAOR,IAAI,CAACC,IAAI,CAACiB,QAAQ,CAAC,GAAG,IAAI;EACnC;;EAEA;EACA;EACA,EAAA,OAAOC,QAAQA,CAACb,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,EAAEvC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EAC1C,IAAA,SAAS4C,GAAGA,CAACC,CAAC,EAAEC,CAAC,EAAE;EACjB,MAAA,OAAOtB,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,GAAGc,CAAC,GAAK9C,CAAC,IAAI,CAAE,CAAC,GAAGwB,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,GAAGa,CAAC,GAAK7C,CAAC,IAAI,CAAE,CAAC;EAC5E;EACA,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC;MAEpB,MAAMS,IAAI,GAAG,CAACP,MAAM,IAAIW,GAAG,CAACX,MAAM,GAAGH,CAAC,EAAEA,CAAC,CAAC,GAAGc,GAAG,CAAC,CAAC,EAAEX,MAAM,CAAC,CAAC,GAAG,CAAC,GAAGH,CAAC,GAAGc,GAAG,CAACX,MAAM,EAAE,CAAC,CAAC,KAChFD,CAAC,GAAGY,GAAG,CAACX,MAAM,EAAEH,CAAC,CAAC,GAAGc,GAAG,CAAC,CAACd,CAAC,EAAE,CAAC,CAAC,CAAC;EACrC,IAAA,OAAOS,EAAE,GAAGC,IAAI,GAAG,IAAI;EACzB;;EAEA;EACA;EACA,EAAA,OAAOO,OAAOA,CAACjB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACrC,IAAA,SAAS4C,GAAGA,CAACC,CAAC,EAAEC,CAAC,EAAE;EACjB,MAAA,OAAOtB,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,GAAGc,CAAC,GAAK9C,CAAC,IAAI,CAAE,CAAC,GAAGwB,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,GAAGa,CAAC,GAAK7C,CAAC,IAAI,CAAE,CAAC;EAC5E;EACA,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC;EAEpB,IAAA,MAAMW,QAAQ,GAEV,EAAE,GAAGZ,CAAC,GAAGc,GAAG,CAAC,CAAC,EAAEX,MAAM,CAAC,IACnB,CAAC,GAAGD,CAAC,GAAGF,CAAC,GAAGc,GAAG,CAACX,MAAM,EAAE,CAAC,GAAGH,CAAC,CAAC,GAAK9B,CAAC,IAAI,CAAC,GAAG4C,GAAG,CAAC,CAAC,EAAEd,CAAC,CAAC,GAAGc,GAAG,CAACX,MAAM,EAAEH,CAAC,CAAE,CAAC,GAC1EN,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,IAEhCgC,CAAC,IAAI,CAAC,GAAGY,GAAG,CAAC,CAAC,EAAEd,CAAC,CAAC,IAAI,CAAC,GAAGc,GAAG,CAACX,MAAM,EAAEH,CAAC,CAAC,IAAI,CAAC,CAC9C,GAED,CACE,CAAC,GAAGE,CAAC,GAAGC,MAAM,IAAI,CAAC,GAAGH,CAAC,GAAGG,MAAM,CAAC,GAAGT,IAAI,CAACW,GAAG,CAAE,CAAC,GAAGH,CAAC,IAAIC,MAAM,GAAGH,CAAC,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,GAC3EiC,MAAM,GAAGjC,CAAC,IAAI,CAAC,GAAG4C,GAAG,CAAC,CAAC,GAAGX,MAAM,EAAE,CAAC,GAAGH,CAAC,CAAC,KAE1CE,CAAC,IAAI,CAAC,GAAGY,GAAG,CAACX,MAAM,EAAEH,CAAC,CAAC,IAAI,CAAC,CAE/B;EAED,IAAA,OAAON,IAAI,CAACC,IAAI,CAACiB,QAAQ,CAAC,GAAG,IAAI;EACnC;;EAEA;EACA,EAAA,OAAOM,QAAQA,CAAClB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,EAAEvC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EAC1C,IAAA,OAAOD,OAAO,CAAC4C,QAAQ,CAACb,CAAC,EAAE,CAAC,GAAGC,CAAC,EAAE,CAACC,CAAC,EAAEO,EAAE,EAAEvC,CAAC,CAAC;EAC9C;;EAEA;EACA,EAAA,OAAOiD,OAAOA,CAACnB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACrC,IAAA,OAAOD,OAAO,CAACgD,OAAO,CAACjB,CAAC,EAAE,CAAC,GAAGC,CAAC,EAAE,CAACC,CAAC,EAAEhC,CAAC,CAAC;EACzC;;EAEA;EACA,EAAA,OAAOkD,OAAOA,CAACC,CAAC,EAAErB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACxC,IAAA,IAAI,CAACmD,CAAC,EAAE,OAAO,CAAC;EAEhB,IAAA,MAAMlB,MAAM,GAAGH,CAAC,GAAGC,CAAC;MACpB,MAAMqB,IAAI,GAAK5B,IAAI,CAAC6B,EAAE,GAAGrD,CAAC,IAAI,CAAC,GAAI8B,CAAC,IAAI,CAAC,GAAIN,IAAI,CAACW,GAAG,CAAE,CAACF,MAAM,GAAGD,CAAC,GAAIhC,CAAC,IAAI,CAAC,CAAC;MAE7E,IAAIsD,CAAC,GAAG,CAAC;MACT,IAAIC,IAAI,GAAG,CAAC;MACZ,IAAIC,GAAG,GAAG,CAAC;MACX,GAAG;EACDF,MAAAA,CAAC,IAAI,CAAC;QAENC,IAAI,GAAGD,CAAC,GACJ9B,IAAI,CAACiC,GAAG,CAAEjC,IAAI,CAAC6B,EAAE,GAAGpB,MAAM,GAAGqB,CAAC,GAAIxB,CAAC,CAAC,GACpCN,IAAI,CAACW,GAAG,CAAC,IAAI,IAAKH,CAAC,IAAI,CAAC,GAAGhC,CAAC,IAAI,CAAC,GAAMwB,IAAI,CAAC6B,EAAE,IAAI,CAAC,GAAGC,CAAC,IAAI,CAAC,GAAGtD,CAAC,IAAI,CAAC,GAAI8B,CAAC,IAAI,CAAE,CAAC,GAAGqB,CAAC,CAAC;EAE1FK,MAAAA,GAAG,IAAID,IAAI;EACb,KAAC,QAAQD,CAAC,GAAG,GAAG,EAAE;;MAElB,OAAOF,IAAI,GAAGI,GAAG;EACnB;;EAEA;EACA,EAAA,OAAOE,OAAOA,CAACP,CAAC,EAAErB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEhC,CAAC,GAAGD,OAAO,CAACC,CAAC,EAAE;EACxC,IAAA,OAAOD,OAAO,CAACmD,OAAO,CAACC,CAAC,EAAErB,CAAC,EAAE,CAAC,GAAGC,CAAC,EAAE,CAACC,CAAC,EAAEhC,CAAC,CAAC;EAC5C;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,EAAA,OAAO2D,OAAOA,CAAC;EACb5C,IAAAA,QAAQ,EAAE6C,EAAE;EACZhC,IAAAA,IAAI,EAAEiC,EAAE;EACR3C,IAAAA,MAAM,EAAE4C,CAAC;EACT9D,IAAAA;EACF,GAAC,EAAE;MACD,SAAS+D,IAAIA,CAACC,CAAC,EAAE;EACf,MAAA,OAASA,CAAC,GAAG,CAAC,GAAI,CAAC,GAAKA,CAAC,KAAK,CAAC,GAAI,CAAC,GAAG,EAAG;EAC5C;MAEA,SAASC,KAAKA,CAACC,CAAC,EAAE;QAChB,OAAO1C,IAAI,CAAC2C,GAAG,CAACD,CAAC,IAAI,CAAC,GAAGA,CAAC,CAAC,CAAC;EAC9B;EAEA,IAAA,MAAME,GAAG,GAAG,CAACP,EAAE,GAAG,IAAI,KAAK,CAAC;EAC5B,IAAA,MAAMQ,GAAG,GAAGP,CAAC,GAAG,IAAI;EAEpB,IAAA,MAAMQ,EAAE,GAAGtE,CAAC,IAAI,CAAC;EACjB,IAAA,MAAMuE,CAAC,GAAGN,KAAK,CAACL,EAAE,CAAC;EACnB,IAAA,MAAMf,CAAC,GAAI0B,CAAC,IAAIA,CAAC,GAAGX,EAAE,IAAI,CAAC,GAAGW,CAAC,GAAGX,EAAE,GAAGA,EAAE,GAAG,GAAG,CAAC,GAAIQ,GAAG;EACvD,IAAA,MAAMpC,CAAC,GAAG+B,IAAI,CAACH,EAAE,GAAG,GAAG,CAAC,GAAG5D,CAAC,GAAG6C,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;MAC3C,MAAMf,CAAC,GAAIwC,EAAE,GAAGL,KAAK,CAACL,EAAE,CAAC,GAAI5B,CAAC;EAC9B,IAAA,MAAMc,CAAC,GAAI,CAACd,CAAC,GAAGF,CAAC,GAAIwC,EAAE;MACvB,MAAME,GAAG,GAAK1C,CAAC,IAAI,CAAC,GAAGE,CAAC,CAAC,IAAK,CAAC,GAAGR,IAAI,CAACW,GAAG,CAACW,CAAC,CAAC,CAAC,IAAK,CAAC,GAAGtB,IAAI,CAACW,GAAG,CAACW,CAAC,CAAC,CAAC;MACnE,MAAMP,EAAE,GAAI8B,GAAG,GAAGA,GAAG,GAAGG,GAAG,GAAG,IAAK,CAAC;;EAEpC,IAAA,MAAMC,OAAO,GAAGlC,EAAE,GAAG,IAAI;MACzB,OAAO;QACLP,CAAC;QACDF,CAAC;EACDS,MAAAA,EAAE,EAAEkC,OAAO;EACXzE,MAAAA;OACD;EACH;IAEA,OAAO0E,QAAQA,GAAG;EAChB,IAAA,MAAM,IAAIC,KAAK,CAAC,8BAA8B,CAAC;EACjD;EACF;;EC7RA;;ECDA;;EAIAC,IAAI,CAACC,SAAS,GAAIC,KAAK,IAAK;EAC1B,EAAA,MAAMC,MAAM,GAAGhF,OAAO,CAAC4D,OAAO,CAAC;MAAC,GAAGmB,KAAK,CAACE,IAAI;MAAEhF,CAAC,EAAED,OAAO,CAACC;EAAC,GAAC,CAAC;;EAE7D;EACA,EAAA,MAAM8B,CAAC,GAAG,CAACmD,KAAK,CAACF,MAAM,CAACjD,CAAC,CAAC,GAAGiD,MAAM,CAACjD,CAAC,GAAG,GAAG;EAC3C,EAAA,MAAMC,CAAC,GAAG,CAACkD,KAAK,CAACF,MAAM,CAAChD,CAAC,CAAC,GAAGgD,MAAM,CAAChD,CAAC,GAAG,GAAG;EAC3C,EAAA,MAAMC,CAAC,GAAG,CAACiD,KAAK,CAACF,MAAM,CAAC/C,CAAC,CAAC,GAAG+C,MAAM,CAAC/C,CAAC,GAAG,GAAG;EAC3C,EAAA,MAAMO,EAAE,GAAG,CAAC0C,KAAK,CAACF,MAAM,CAACxC,EAAE,CAAC,GAAGwC,MAAM,CAACxC,EAAE,GAAG,GAAG;EAC9C,EAAA,MAAMvC,CAAC,GAAG,CAACiF,KAAK,CAACF,MAAM,CAAC/E,CAAC,CAAC,GAAG+E,MAAM,CAAC/E,CAAC,GAAGD,OAAO,CAACC,CAAC;EAEjD,EAAA,MAAMkF,SAAS,GAAG;MAChBnE,QAAQ,EAAEhB,OAAO,CAACsC,MAAM,CAACP,CAAC,EAAEC,CAAC,EAAEC,CAAC,CAAC;EACjChB,IAAAA,aAAa,EAAEjB,OAAO,CAACiD,QAAQ,CAAClB,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,CAAC;EAC5CtB,IAAAA,WAAW,EAAElB,OAAO,CAAC4C,QAAQ,CAACb,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,CAAC;EAC1CrB,IAAAA,MAAM,EAAEnB,OAAO,CAACuC,OAAO,CAACR,CAAC,EAAEC,CAAC,EAAEC,CAAC,EAAEO,EAAE,CAAC;MACpChB,WAAW,EAAExB,OAAO,CAACkD,OAAO,CAACnB,CAAC,EAAEC,CAAC,EAAEC,CAAC,CAAC;MACrCL,SAAS,EAAE5B,OAAO,CAACgD,OAAO,CAACjB,CAAC,EAAEC,CAAC,EAAEC,CAAC,CAAC;MACnCJ,IAAI,EAAE7B,OAAO,CAAC0C,MAAM,CAACX,CAAC,EAAEC,CAAC,EAAEC,CAAC;KAC7B;IAED4C,IAAI,CAACO,WAAW,CAAC;EACfJ,IAAAA,MAAM,EAAE;QACNjD,CAAC;QAAEC,CAAC;QAAEC,CAAC;QAAEO,EAAE;EAAEvC,MAAAA;OACd;EACDkF,IAAAA;EACF,GAAC,CAAC;EACJ,CAAC;;;;;;"}');
|
|
7342
|
+
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

    Model parameters:
      a = boundary separation [0, Infinity)
      z = starting point as a proportion of a (0, 1)
      v = drift rate (per second) (-Infinity, Infinity)
      t0 = non-decision time (in milliseconds) (0, Infinity)
      s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)

      zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)

    Behavioral variables:
      pE = proportion of error trials
      pC = proportion of correct trials
      m = mean of overall RTs (in milliseconds)
      mE = mean of error RTs (in milliseconds)
      mC = mean correct RTs (in milliseconds)
      sd = standard deviation of overall RTs (in milliseconds)
      sdE = standard deviation of error RTs (in milliseconds)
      sdC = standard deviation of correct RTs (in milliseconds)

    Equations:
      Probability of correct and error responses (Alexandrowicz, 2020)
      Mean of overall, error, and correct RTs (Grasman et al., 2009)
      Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)
      Density of error and correct RT distributions (Alexandrowicz, 2020)
      EZ-diffusion model (Wagenmakers et al., 2007)
  */
  class DDMMath {
    static s = {
      DEFAULT: 1
    };
    static a = {
      DEFAULT: 1.2,
      MIN: 0.01,
      MAX: 2.0,
      STEP: 0.01,
      JUMP: 0.1
    };
    static z = {
      DEFAULT: 0.55,
      MIN: 0.01,
      MAX: 0.99,
      STEP: 0.01,
      JUMP: 0.1
    };
    static v = {
      DEFAULT: 1.5,
      MIN: 0.01,
      MAX: 5.0,
      STEP: 0.01,
      JUMP: 0.1
    };
    static t0 = {
      DEFAULT: 150,
      MIN: 0,
      MAX: 500,
      STEP: 1,
      JUMP: 10
    };

    // Calculate a bunch of statistics for an array of trials
    static trials2stats(trials) {
      const stats = {};

      // First-order sums
      const sums = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.correctCount += 1;
            accumulator.correctRTSum += trial.rt;
            break;
          case 'error':
            accumulator.errorCount += 1;
            accumulator.errorRTSum += trial.rt;
            break;
          case 'nr':
            accumulator.nrCount += 1;
            break;
          // No-op
        }
        return accumulator;
      }, {
        correctCount: 0,
        errorCount: 0,
        nrCount: 0,
        correctRTSum: 0,
        errorRTSum: 0
      });

      // First-order stats
      stats.correctCount = sums.correctCount;
      stats.errorCount = sums.errorCount;
      stats.nrCount = sums.nrCount;
      stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);
      stats.correctMeanRT = sums.correctRTSum / sums.correctCount;
      stats.errorMeanRT = sums.errorRTSum / sums.errorCount;
      stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);

      // Second-order sums
      const sums2 = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;
            break;
          case 'error':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;
            break;
          // No-op
        }
        return accumulator;
      }, {
        ss: 0,
        correctSS: 0,
        errorSS: 0
      });

      // Second-order stats
      stats.correctSDRT = stats.correctCount > 1 ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1)) : NaN;
      stats.errorSDRT = stats.errorCount > 1 ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1)) : NaN;
      stats.sdRT = stats.correctCount + stats.errorCount > 1 ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1)) : NaN;
      return stats;
    }

    // Probability of an Error Response
    static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2);
      const Z = Math.exp(-2 * v * zPrime / s ** 2);
      return (A - Z) / (A - 1);
    }

    // Probability of a Correct Response
    static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.azv2pE(a, 1 - z, -v, s);
    }

    // Mean Overall RT
    // Equation 5 (Grasman et al., 2009)
    static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const mean = -(zPrime / v) + a / v * (Z / A);
      return t0 + mean * 1000;
    }

    // SD Overall RT
    // Equation 6 (Grasman et al., 2009)
    static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const variance = (-v * a ** 2 * (Z + 4) * Z / A ** 2 + ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A - s ** 2 * zPrime) / v ** 3;
      return Math.sqrt(variance) * 1000;
    }

    // Mean Error RT
    // Equation 13 (Grasman et al., 2009)
    static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0)) / (v * phi(zPrime, a) * phi(-a, 0));
      return t0 + mean * 1000;
    }

    // SD Error RT
    // Equation 14 (Grasman et al., 2009)
    static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const variance = -2 * a * phi(0, zPrime) * (2 * v * a * phi(zPrime, 2 * a) + s ** 2 * phi(0, a) * phi(zPrime, a)) * Math.exp(2 * v * a / s ** 2) / (v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2) + (4 * v * zPrime * (2 * a - zPrime) * Math.exp(2 * v * (zPrime + a) / s ** 2) + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)) / (v ** 3 * phi(zPrime, a) ** 2);
      return Math.sqrt(variance) * 1000;
    }

    // Mean Correct RT
    static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
    }

    // SD Correct RT
    static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.azv2sdE(a, 1 - z, -v, s);
    }

    // Density of Error RT
    static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
      if (!t) return 0;
      const zPrime = a * z;
      const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
      let k = 0;
      let term = 0;
      let sum = 0;
      do {
        k += 1;
        term = k * Math.sin(Math.PI * zPrime * k / a) * Math.exp(-0.5 * (v ** 2 / s ** 2 + Math.PI ** 2 * k ** 2 * s ** 2 / a ** 2) * t);
        sum += term;
      } while (k < 200); // ?? HACK

      return base * sum;
    }

    // Density of Correct RT
    static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
    }

    // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html
    // EZ-function for starting values
    // input: obj - Object with properties
    //    pC - Proportion correct
    //    sd - sample standard deviation of the RT's in ms
    //    m - sample mean of the RT's in ms
    //    s - diffusion standard deviation
    // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters
    static data2ez({
      accuracy: pC,
      sdRT: sd,
      meanRT: m,
      s
    }) {
      function sign(r) {
        return r > 0 ? 1 : r === 0 ? 0 : -1;
      }
      function logit(p) {
        return Math.log(p / (1 - p));
      }
      const vrt = (sd / 1000) ** 2;
      const mrt = m / 1000;
      const s2 = s ** 2;
      const l = logit(pC);
      const x = l * (l * pC ** 2 - l * pC + pC - 0.5) / vrt;
      const v = sign(pC - 0.5) * s * x ** (1 / 4);
      const a = s2 * logit(pC) / v;
      const y = -v * a / s2;
      const mdt = a / (2 * v) * (1 - Math.exp(y)) / (1 + Math.exp(y));
      const t0 = mrt ? mrt - mdt : null; // compute Ter only if MRT was provided

      const t0Prime = t0 * 1000;
      return {
        v,
        a,
        t0: t0Prime,
        s
      };
    }
    static data2ez2() {
      throw new Error('data2ez2 is not implemented!');
    }
  }

  // Internal dependencies

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

  self.onmessage = event => {
    const params = DDMMath.data2ez({
      ...event.data,
      s: DDMMath.s.DEFAULT
    });

    // ##### Arbitrary default values!!!
    const a = !isNaN(params.a) ? params.a : 1.5;
    const z = !isNaN(params.z) ? params.z : 0.5;
    const v = !isNaN(params.v) ? params.v : 0.1;
    const t0 = !isNaN(params.t0) ? params.t0 : 100;
    const s = !isNaN(params.s) ? params.s : DDMMath.s.DEFAULT;
    const predicted = {
      accuracy: DDMMath.azv2pC(a, z, v),
      correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),
      errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),
      meanRT: DDMMath.azvt02m(a, z, v, t0),
      correctSDRT: DDMMath.azv2sdC(a, z, v),
      errorSDRT: DDMMath.azv2sdE(a, z, v),
      sdRT: DDMMath.azv2sd(a, z, v)
    };
    self.postMessage({
      params: {
        a,
        z,
        v,
        t0,
        s
      },
      predicted
    });
  };

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

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation [0, Infinity)\n    z = starting point as a proportion of a (0, 1)\n    v = drift rate (per second) (-Infinity, Infinity)\n    t0 = non-decision time (in milliseconds) (0, Infinity)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = {\n    DEFAULT: 1,\n  };\n\n  static a = {\n    DEFAULT: 1.2,\n    MIN: 0.01,\n    MAX: 2.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static z = {\n    DEFAULT: 0.55,\n    MIN: 0.01,\n    MAX: 0.99,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static v = {\n    DEFAULT: 1.5,\n    MIN: 0.01,\n    MAX: 5.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static t0 = {\n    DEFAULT: 150,\n    MIN: 0,\n    MAX: 500,\n    STEP: 1,\n    JUMP: 10,\n  };\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s.DEFAULT});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s.DEFAULT;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","DEFAULT","a","MIN","MAX","STEP","JUMP","z","v","t0","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","zPrime","A","exp","Z","azv2pC","azvt02m","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":"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"}');
|
|
7238
7343
|
/* eslint-enable */
|
|
7239
7344
|
|
|
7240
7345
|
/*
|
|
@@ -7250,10 +7355,10 @@
|
|
|
7250
7355
|
}
|
|
7251
7356
|
constructor() {
|
|
7252
7357
|
super();
|
|
7253
|
-
this.a =
|
|
7254
|
-
this.z =
|
|
7255
|
-
this.v =
|
|
7256
|
-
this.t0 =
|
|
7358
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7359
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7360
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7361
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7257
7362
|
this.observed = {};
|
|
7258
7363
|
this.predicted = {};
|
|
7259
7364
|
this.working = false;
|
|
@@ -7440,15 +7545,71 @@
|
|
|
7440
7545
|
decidables-slider div {
|
|
7441
7546
|
margin-bottom: 0.25rem;
|
|
7442
7547
|
}
|
|
7548
|
+
|
|
7549
|
+
.a {
|
|
7550
|
+
--decidables-slider-background-color: var(---color-a-light);
|
|
7551
|
+
--decidables-slider-color: var(---color-a);
|
|
7552
|
+
}
|
|
7553
|
+
|
|
7554
|
+
.z {
|
|
7555
|
+
--decidables-slider-background-color: var(---color-z-light);
|
|
7556
|
+
--decidables-slider-color: var(---color-z);
|
|
7557
|
+
}
|
|
7558
|
+
|
|
7559
|
+
.v {
|
|
7560
|
+
--decidables-slider-background-color: var(---color-v-light);
|
|
7561
|
+
--decidables-slider-color: var(---color-v);
|
|
7562
|
+
}
|
|
7563
|
+
|
|
7564
|
+
.t0 {
|
|
7565
|
+
--decidables-slider-background-color: var(---color-t0-light);
|
|
7566
|
+
--decidables-slider-color: var(---color-t0);
|
|
7567
|
+
}
|
|
7443
7568
|
`];
|
|
7444
7569
|
}
|
|
7445
7570
|
render() {
|
|
7446
7571
|
return x$1`
|
|
7447
7572
|
<div class="holder">
|
|
7448
|
-
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7449
|
-
|
|
7450
|
-
|
|
7451
|
-
|
|
7573
|
+
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7574
|
+
?disabled=${!this.interactive}
|
|
7575
|
+
scale
|
|
7576
|
+
min=${DDMMath.a.MIN}
|
|
7577
|
+
max=${DDMMath.a.MAX}
|
|
7578
|
+
step=${DDMMath.a.STEP}
|
|
7579
|
+
.value=${+this.a.toFixed(2)}
|
|
7580
|
+
@change=${this.setBoundarySeparation.bind(this)}
|
|
7581
|
+
@input=${this.setBoundarySeparation.bind(this)}
|
|
7582
|
+
><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
|
|
7583
|
+
${this.z != null ? x$1`<decidables-slider class="z"
|
|
7584
|
+
?disabled=${!this.interactive}
|
|
7585
|
+
scale
|
|
7586
|
+
min=${DDMMath.z.MIN}
|
|
7587
|
+
max=${DDMMath.z.MAX}
|
|
7588
|
+
step=${DDMMath.z.STEP}
|
|
7589
|
+
.value=${+this.z.toFixed(2)}
|
|
7590
|
+
@change=${this.setStartingPoint.bind(this)}
|
|
7591
|
+
@input=${this.setStartingPoint.bind(this)}
|
|
7592
|
+
><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
|
|
7593
|
+
${this.v != null ? x$1`<decidables-slider class="v"
|
|
7594
|
+
?disabled=${!this.interactive}
|
|
7595
|
+
scale
|
|
7596
|
+
min=${DDMMath.v.MIN}
|
|
7597
|
+
max=${DDMMath.v.MAX}
|
|
7598
|
+
step=${DDMMath.v.STEP}
|
|
7599
|
+
.value=${+this.v.toFixed(2)}
|
|
7600
|
+
@change=${this.setDriftRate.bind(this)}
|
|
7601
|
+
@input=${this.setDriftRate.bind(this)}
|
|
7602
|
+
><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
|
|
7603
|
+
${this.t0 != null ? x$1`<decidables-slider class="t0"
|
|
7604
|
+
?disabled=${!this.interactive}
|
|
7605
|
+
scale
|
|
7606
|
+
min=${DDMMath.t0.MIN}
|
|
7607
|
+
max=${DDMMath.t0.MAX}
|
|
7608
|
+
step=${DDMMath.t0.STEP}
|
|
7609
|
+
.value=${+this.t0.toFixed(0)}
|
|
7610
|
+
@change=${this.setNondecisionTime.bind(this)}
|
|
7611
|
+
@input=${this.setNondecisionTime.bind(this)}
|
|
7612
|
+
><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
|
|
7452
7613
|
</div>`;
|
|
7453
7614
|
}
|
|
7454
7615
|
}
|
|
@@ -7586,10 +7747,10 @@
|
|
|
7586
7747
|
this.resample();
|
|
7587
7748
|
this.human = false;
|
|
7588
7749
|
this.trials = 10;
|
|
7589
|
-
this.a =
|
|
7590
|
-
this.z =
|
|
7591
|
-
this.v =
|
|
7592
|
-
this.t0 =
|
|
7750
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7751
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7752
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7753
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7593
7754
|
|
|
7594
7755
|
// this.s = null;
|
|
7595
7756
|
// this.sz = null;
|
|
@@ -7650,7 +7811,7 @@
|
|
|
7650
7811
|
while (path.at(-1).e > bounds.lower && path.at(-1).e < bounds.upper) {
|
|
7651
7812
|
path.push({
|
|
7652
7813
|
t: path.at(-1).t + this.precision * 1000,
|
|
7653
|
-
e: path.at(-1).e + drift + DDMMath.s * random()
|
|
7814
|
+
e: path.at(-1).e + drift + DDMMath.s.DEFAULT * random()
|
|
7654
7815
|
});
|
|
7655
7816
|
}
|
|
7656
7817
|
return path;
|
|
@@ -7940,10 +8101,25 @@
|
|
|
7940
8101
|
|
|
7941
8102
|
.t0z .point {
|
|
7942
8103
|
fill: var(---color-element-emphasis);
|
|
8104
|
+
stroke-width: 0;
|
|
7943
8105
|
|
|
7944
8106
|
r: 6px;
|
|
7945
8107
|
}
|
|
7946
8108
|
|
|
8109
|
+
/* Make larger targets for touch users */
|
|
8110
|
+
.interactive .touch {
|
|
8111
|
+
stroke: #000000;
|
|
8112
|
+
stroke-dasharray: none;
|
|
8113
|
+
stroke-opacity: 0;
|
|
8114
|
+
}
|
|
8115
|
+
|
|
8116
|
+
@media (pointer: coarse) {
|
|
8117
|
+
.interactive .touch {
|
|
8118
|
+
stroke-linecap: round;
|
|
8119
|
+
stroke-width: 12;
|
|
8120
|
+
}
|
|
8121
|
+
}
|
|
8122
|
+
|
|
7947
8123
|
.measure {
|
|
7948
8124
|
stroke-width: 2;
|
|
7949
8125
|
}
|
|
@@ -8118,9 +8294,9 @@
|
|
|
8118
8294
|
let t0 = timeScale.invert(event.x);
|
|
8119
8295
|
let z = (evidenceScale.invert(event.y) + this.a / 2) / this.a;
|
|
8120
8296
|
// Clamp t0
|
|
8121
|
-
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 <
|
|
8297
|
+
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8122
8298
|
// Clamp z
|
|
8123
|
-
z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z <
|
|
8299
|
+
z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
|
|
8124
8300
|
this.t0 = t0;
|
|
8125
8301
|
this.z = z;
|
|
8126
8302
|
this.alignState();
|
|
@@ -8150,7 +8326,7 @@
|
|
|
8150
8326
|
this.drag = true;
|
|
8151
8327
|
let v = (evidenceScale.invert(event.y) - this.startingPoint) / (timeScale.invert(event.x) - this.t0) * 1000;
|
|
8152
8328
|
// Clamp drift rate
|
|
8153
|
-
v = v <
|
|
8329
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8154
8330
|
this.v = v;
|
|
8155
8331
|
this.alignState();
|
|
8156
8332
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8174,12 +8350,13 @@
|
|
|
8174
8350
|
}).on('start', event => {
|
|
8175
8351
|
const element = event.currentTarget;
|
|
8176
8352
|
select(element).classed('dragging', true);
|
|
8177
|
-
}).on('drag',
|
|
8353
|
+
}).on('drag', event => {
|
|
8178
8354
|
this.drag = true;
|
|
8179
|
-
|
|
8180
|
-
|
|
8181
|
-
|
|
8182
|
-
|
|
8355
|
+
const boundary = evidenceScale.invert(event.y);
|
|
8356
|
+
let a = Math.abs(boundary * 2);
|
|
8357
|
+
// Clamp a
|
|
8358
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8359
|
+
this.a = a;
|
|
8183
8360
|
this.alignState();
|
|
8184
8361
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
8185
8362
|
detail: {
|
|
@@ -8620,20 +8797,23 @@
|
|
|
8620
8797
|
return `boundary ${index === 0 ? 'correct' : 'error'}`;
|
|
8621
8798
|
});
|
|
8622
8799
|
boundaryEnter.append('line').classed('line', true);
|
|
8800
|
+
boundaryEnter.append('line').classed('line touch', true);
|
|
8623
8801
|
// MERGE
|
|
8624
8802
|
const boundaryMerge = boundaryEnter.merge(boundaryUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? (event, datum) => {
|
|
8625
8803
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8626
|
-
let
|
|
8804
|
+
let {
|
|
8805
|
+
a
|
|
8806
|
+
} = this;
|
|
8627
8807
|
switch (event.key) {
|
|
8628
8808
|
case 'ArrowUp':
|
|
8629
|
-
a += datum.bound === 'upper' ? event.shiftKey ?
|
|
8809
|
+
a += datum.bound === 'upper' ? event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP : event.shiftKey ? -0.01 : -0.1;
|
|
8630
8810
|
break;
|
|
8631
8811
|
case 'ArrowDown':
|
|
8632
|
-
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ?
|
|
8812
|
+
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP;
|
|
8633
8813
|
break;
|
|
8634
8814
|
}
|
|
8635
|
-
// Clamp
|
|
8636
|
-
a = a <
|
|
8815
|
+
// Clamp a
|
|
8816
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8637
8817
|
this.a = a;
|
|
8638
8818
|
this.alignState();
|
|
8639
8819
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
@@ -8657,6 +8837,11 @@
|
|
|
8657
8837
|
}).attr('y2', datum => {
|
|
8658
8838
|
return evidenceScale(datum.value);
|
|
8659
8839
|
});
|
|
8840
|
+
boundaryMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(this.scale.time.min)).attr('x2', timeScale(this.scale.time.max)).attr('y1', datum => {
|
|
8841
|
+
return evidenceScale(datum.value);
|
|
8842
|
+
}).attr('y2', datum => {
|
|
8843
|
+
return evidenceScale(datum.value);
|
|
8844
|
+
});
|
|
8660
8845
|
// EXIT
|
|
8661
8846
|
boundaryUpdate.exit().remove();
|
|
8662
8847
|
|
|
@@ -8670,21 +8855,25 @@
|
|
|
8670
8855
|
// ENTER
|
|
8671
8856
|
const driftEnter = driftUpdate.enter().append('g').classed('drift', true);
|
|
8672
8857
|
driftEnter.append('line').classed('line', true);
|
|
8858
|
+
driftEnter.append('line').classed('line touch', true);
|
|
8673
8859
|
driftEnter.append('path').classed('arrow', true);
|
|
8860
|
+
driftEnter.append('path').classed('arrow touch', true);
|
|
8674
8861
|
// MERGE
|
|
8675
8862
|
const driftMerge = driftEnter.merge(driftUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8676
8863
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8677
|
-
let
|
|
8864
|
+
let {
|
|
8865
|
+
v
|
|
8866
|
+
} = this;
|
|
8678
8867
|
switch (event.key) {
|
|
8679
8868
|
case 'ArrowUp':
|
|
8680
|
-
v += event.shiftKey ?
|
|
8869
|
+
v += event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8681
8870
|
break;
|
|
8682
8871
|
case 'ArrowDown':
|
|
8683
|
-
v -= event.shiftKey ?
|
|
8872
|
+
v -= event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8684
8873
|
break;
|
|
8685
8874
|
}
|
|
8686
8875
|
// Clamp z
|
|
8687
|
-
v = v <
|
|
8876
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8688
8877
|
this.v = v;
|
|
8689
8878
|
this.alignState();
|
|
8690
8879
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8709,11 +8898,17 @@
|
|
|
8709
8898
|
rotate(${-Math.atan(datum.v / 1000 * scaleRatio) * (180 / Math.PI)})`;
|
|
8710
8899
|
});
|
|
8711
8900
|
driftMerge.select('.line').attr('x2', timeScale(200));
|
|
8901
|
+
driftMerge.select('.line.touch').attr('x2', timeScale(200));
|
|
8712
8902
|
driftMerge.select('.arrow').attr('d', `
|
|
8713
8903
|
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8714
8904
|
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8715
8905
|
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8716
8906
|
`);
|
|
8907
|
+
driftMerge.select('.arrow.touch').attr('d', `
|
|
8908
|
+
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8909
|
+
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8910
|
+
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8911
|
+
`);
|
|
8717
8912
|
// EXIT
|
|
8718
8913
|
driftUpdate.exit().remove();
|
|
8719
8914
|
|
|
@@ -8726,21 +8921,24 @@
|
|
|
8726
8921
|
// ENTER
|
|
8727
8922
|
const t0zEnter = t0zUpdate.enter().append('g').classed('t0z', true);
|
|
8728
8923
|
t0zEnter.append('line').classed('line', true);
|
|
8729
|
-
t0zEnter.append('
|
|
8924
|
+
t0zEnter.append('line').classed('line touch', true);
|
|
8925
|
+
t0zEnter.append('circle').classed('point touch', true);
|
|
8730
8926
|
// MERGE
|
|
8731
8927
|
const t0zMerge = t0zEnter.merge(t0zUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8732
8928
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8733
|
-
let
|
|
8929
|
+
let {
|
|
8930
|
+
z
|
|
8931
|
+
} = this;
|
|
8734
8932
|
switch (event.key) {
|
|
8735
8933
|
case 'ArrowUp':
|
|
8736
|
-
z += event.shiftKey ?
|
|
8934
|
+
z += event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8737
8935
|
break;
|
|
8738
8936
|
case 'ArrowDown':
|
|
8739
|
-
z -= event.shiftKey ?
|
|
8937
|
+
z -= event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8740
8938
|
break;
|
|
8741
8939
|
}
|
|
8742
8940
|
// Clamp z
|
|
8743
|
-
z = z <
|
|
8941
|
+
z = z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
|
|
8744
8942
|
this.z = z;
|
|
8745
8943
|
this.alignState();
|
|
8746
8944
|
this.dispatchEvent(new CustomEvent('ddm-model-z', {
|
|
@@ -8755,14 +8953,14 @@
|
|
|
8755
8953
|
let t0 = this.t0; /* eslint-disable-line prefer-destructuring */
|
|
8756
8954
|
switch (event.key) {
|
|
8757
8955
|
case 'ArrowRight':
|
|
8758
|
-
t0 += event.shiftKey ?
|
|
8956
|
+
t0 += event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8759
8957
|
break;
|
|
8760
8958
|
case 'ArrowLeft':
|
|
8761
|
-
t0 -= event.shiftKey ?
|
|
8959
|
+
t0 -= event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8762
8960
|
break;
|
|
8763
8961
|
}
|
|
8764
8962
|
// Clamp t0
|
|
8765
|
-
t0 = t0 <
|
|
8963
|
+
t0 = t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8766
8964
|
this.t0 = t0;
|
|
8767
8965
|
this.alignState();
|
|
8768
8966
|
this.dispatchEvent(new CustomEvent('ddm-model-t0', {
|
|
@@ -8788,6 +8986,13 @@
|
|
|
8788
8986
|
}).attr('y2', datum => {
|
|
8789
8987
|
return evidenceScale(datum.startingPoint);
|
|
8790
8988
|
});
|
|
8989
|
+
t0zMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(0)).attr('x2', datum => {
|
|
8990
|
+
return timeScale(datum.t0);
|
|
8991
|
+
}).attr('y1', datum => {
|
|
8992
|
+
return evidenceScale(datum.startingPoint);
|
|
8993
|
+
}).attr('y2', datum => {
|
|
8994
|
+
return evidenceScale(datum.startingPoint);
|
|
8995
|
+
});
|
|
8791
8996
|
t0zMerge.select('.point').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('cx', datum => {
|
|
8792
8997
|
return timeScale(datum.t0);
|
|
8793
8998
|
}).attr('cy', datum => {
|
|
@@ -9670,9 +9875,9 @@
|
|
|
9670
9875
|
}
|
|
9671
9876
|
constructor() {
|
|
9672
9877
|
super();
|
|
9673
|
-
this.a =
|
|
9674
|
-
this.z =
|
|
9675
|
-
this.v =
|
|
9878
|
+
this.a = DDMMath.a.DEFAULT;
|
|
9879
|
+
this.z = DDMMath.z.DEFAULT;
|
|
9880
|
+
this.v = DDMMath.v.DEFAULT;
|
|
9676
9881
|
this.alignState();
|
|
9677
9882
|
}
|
|
9678
9883
|
alignState() {
|
|
@@ -9714,19 +9919,46 @@
|
|
|
9714
9919
|
let s;
|
|
9715
9920
|
let accuracy;
|
|
9716
9921
|
if (this.numeric) {
|
|
9717
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
9922
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
9923
|
+
?disabled=${!this.interactive}
|
|
9924
|
+
min=${DDMMath.a.MIN}
|
|
9925
|
+
max=${DDMMath.a.MAX}
|
|
9926
|
+
step=${DDMMath.a.STEP}
|
|
9927
|
+
.value=${this.a}
|
|
9928
|
+
@input=${this.aInput.bind(this)}
|
|
9929
|
+
>
|
|
9718
9930
|
<var class="math-var">a</var>
|
|
9719
9931
|
</decidables-spinner>`;
|
|
9720
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
9932
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
9933
|
+
?disabled=${!this.interactive}
|
|
9934
|
+
min=${DDMMath.z.MIN}
|
|
9935
|
+
max=${DDMMath.z.MAX}
|
|
9936
|
+
step=${DDMMath.z.STEP}
|
|
9937
|
+
.value=${this.z}
|
|
9938
|
+
@input=${this.zInput.bind(this)}
|
|
9939
|
+
>
|
|
9721
9940
|
<var class="math-var">z</var>
|
|
9722
9941
|
</decidables-spinner>`;
|
|
9723
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
9942
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
9943
|
+
?disabled=${!this.interactive}
|
|
9944
|
+
min=${DDMMath.v.MIN}
|
|
9945
|
+
max=${DDMMath.v.MAX}
|
|
9946
|
+
step=${DDMMath.v.STEP}
|
|
9947
|
+
.value=${this.v}
|
|
9948
|
+
@input=${this.vInput.bind(this)}
|
|
9949
|
+
>
|
|
9724
9950
|
<var class="math-var">v</var>
|
|
9725
9951
|
</decidables-spinner>`;
|
|
9726
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
9952
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
9953
|
+
disabled
|
|
9954
|
+
.value=${DDMMath.s.DEFAULT}
|
|
9955
|
+
>
|
|
9727
9956
|
<var class="math-var">s</var>
|
|
9728
9957
|
</decidables-spinner>`;
|
|
9729
|
-
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9958
|
+
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9959
|
+
disabled
|
|
9960
|
+
.value=${+this.accuracy.toFixed(2)}
|
|
9961
|
+
>
|
|
9730
9962
|
<var>Accuracy</var>
|
|
9731
9963
|
</decidables-spinner>`;
|
|
9732
9964
|
} else {
|
|
@@ -9804,10 +10036,10 @@
|
|
|
9804
10036
|
}
|
|
9805
10037
|
constructor() {
|
|
9806
10038
|
super();
|
|
9807
|
-
this.a =
|
|
9808
|
-
this.z =
|
|
9809
|
-
this.v =
|
|
9810
|
-
this.t0 =
|
|
10039
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10040
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10041
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10042
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
9811
10043
|
this.alignState();
|
|
9812
10044
|
}
|
|
9813
10045
|
alignState() {
|
|
@@ -9856,22 +10088,56 @@
|
|
|
9856
10088
|
let s;
|
|
9857
10089
|
let meanRT;
|
|
9858
10090
|
if (this.numeric) {
|
|
9859
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
10091
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
10092
|
+
?disabled=${!this.interactive}
|
|
10093
|
+
min=${DDMMath.a.MIN}
|
|
10094
|
+
max=${DDMMath.a.MAX}
|
|
10095
|
+
step=${DDMMath.a.STEP}
|
|
10096
|
+
.value=${this.a}
|
|
10097
|
+
@input=${this.aInput.bind(this)}
|
|
10098
|
+
>
|
|
9860
10099
|
<var class="math-var">a</var>
|
|
9861
10100
|
</decidables-spinner>`;
|
|
9862
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
10101
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
10102
|
+
?disabled=${!this.interactive}
|
|
10103
|
+
min=${DDMMath.z.MIN}
|
|
10104
|
+
max=${DDMMath.z.MAX}
|
|
10105
|
+
step=${DDMMath.z.STEP}
|
|
10106
|
+
.value=${this.z}
|
|
10107
|
+
@input=${this.zInput.bind(this)}
|
|
10108
|
+
>
|
|
9863
10109
|
<var class="math-var">z</var>
|
|
9864
10110
|
</decidables-spinner>`;
|
|
9865
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
10111
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
10112
|
+
?disabled=${!this.interactive}
|
|
10113
|
+
min=${DDMMath.v.MIN}
|
|
10114
|
+
max=${DDMMath.v.MAX}
|
|
10115
|
+
step=${DDMMath.v.STEP}
|
|
10116
|
+
.value=${this.v}
|
|
10117
|
+
@input=${this.vInput.bind(this)}
|
|
10118
|
+
>
|
|
9866
10119
|
<var class="math-var">v</var>
|
|
9867
10120
|
</decidables-spinner>`;
|
|
9868
|
-
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10121
|
+
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10122
|
+
?disabled=${!this.interactive}
|
|
10123
|
+
min=${DDMMath.t0.MIN}
|
|
10124
|
+
max=${DDMMath.t0.MAX}
|
|
10125
|
+
step=${DDMMath.t0.STEP}
|
|
10126
|
+
.value=${this.t0}
|
|
10127
|
+
@input=${this.t0Input.bind(this)}
|
|
10128
|
+
>
|
|
9869
10129
|
<var class="math-var">t<sub>0</sub></var>
|
|
9870
10130
|
</decidables-spinner>`;
|
|
9871
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
10131
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
10132
|
+
disabled
|
|
10133
|
+
.value=${DDMMath.s.DEFAULT}
|
|
10134
|
+
>
|
|
9872
10135
|
<var class="math-var">s</var>
|
|
9873
10136
|
</decidables-spinner>`;
|
|
9874
|
-
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10137
|
+
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10138
|
+
disabled
|
|
10139
|
+
.value=${+this.meanRT.toFixed(0)}
|
|
10140
|
+
>
|
|
9875
10141
|
<var>Mean RT</var>
|
|
9876
10142
|
</decidables-spinner>`;
|
|
9877
10143
|
} else {
|
|
@@ -9994,17 +10260,74 @@
|
|
|
9994
10260
|
}
|
|
9995
10261
|
customElements.define('ddm-example', DDMExample);
|
|
9996
10262
|
|
|
9997
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
9998
|
-
|
|
9999
|
-
|
|
10000
10263
|
/*
|
|
10001
10264
|
DDMExampleHuman element
|
|
10002
10265
|
<ddm-example-human>
|
|
10003
10266
|
*/
|
|
10004
10267
|
class DDMExampleHuman extends DDMExample {
|
|
10268
|
+
static get properties() {
|
|
10269
|
+
return {
|
|
10270
|
+
trials: {
|
|
10271
|
+
attribute: 'trials',
|
|
10272
|
+
type: Number,
|
|
10273
|
+
reflect: true
|
|
10274
|
+
},
|
|
10275
|
+
duration: {
|
|
10276
|
+
attribute: 'duration',
|
|
10277
|
+
type: Number,
|
|
10278
|
+
reflect: true
|
|
10279
|
+
},
|
|
10280
|
+
coherence: {
|
|
10281
|
+
attribute: 'coherence',
|
|
10282
|
+
type: Number,
|
|
10283
|
+
reflect: true
|
|
10284
|
+
},
|
|
10285
|
+
color: {
|
|
10286
|
+
attribute: 'color',
|
|
10287
|
+
type: String,
|
|
10288
|
+
reflect: true
|
|
10289
|
+
},
|
|
10290
|
+
a: {
|
|
10291
|
+
attribute: false,
|
|
10292
|
+
type: Number,
|
|
10293
|
+
reflect: false
|
|
10294
|
+
},
|
|
10295
|
+
z: {
|
|
10296
|
+
attribute: false,
|
|
10297
|
+
type: Number,
|
|
10298
|
+
reflect: false
|
|
10299
|
+
},
|
|
10300
|
+
v: {
|
|
10301
|
+
attribute: false,
|
|
10302
|
+
type: Number,
|
|
10303
|
+
reflect: false
|
|
10304
|
+
},
|
|
10305
|
+
t0: {
|
|
10306
|
+
attribute: false,
|
|
10307
|
+
type: Number,
|
|
10308
|
+
reflect: false
|
|
10309
|
+
}
|
|
10310
|
+
};
|
|
10311
|
+
}
|
|
10005
10312
|
constructor() {
|
|
10006
10313
|
super();
|
|
10007
|
-
this.
|
|
10314
|
+
this.trials = 10;
|
|
10315
|
+
this.duration = 2000;
|
|
10316
|
+
this.coherence = 0.5;
|
|
10317
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10318
|
+
this.color = 'outcome';
|
|
10319
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10320
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10321
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10322
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10323
|
+
this.accumulableControl = null;
|
|
10324
|
+
this.rdkTask = null;
|
|
10325
|
+
this.accumulableResponse = null;
|
|
10326
|
+
this.accumulableTable = null;
|
|
10327
|
+
this.ddmParameters = null;
|
|
10328
|
+
this.ddmModel = null;
|
|
10329
|
+
this.ddmFit = null;
|
|
10330
|
+
this.data = undefined;
|
|
10008
10331
|
}
|
|
10009
10332
|
connectedCallback() {
|
|
10010
10333
|
super.connectedCallback();
|
|
@@ -10018,56 +10341,31 @@
|
|
|
10018
10341
|
|
|
10019
10342
|
// Initialize
|
|
10020
10343
|
this.ddmModel.clear();
|
|
10021
|
-
if (this.accumulableControl
|
|
10344
|
+
if (this.accumulableControl) {
|
|
10022
10345
|
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10023
|
-
|
|
10024
|
-
this.rdkTask.trials = event.detail.trials;
|
|
10025
|
-
}
|
|
10026
|
-
if (this.accumulableResponse) {
|
|
10027
|
-
this.accumulableResponse.trialTotal = event.detail.trials;
|
|
10028
|
-
}
|
|
10346
|
+
this.trials = event.detail.trials;
|
|
10029
10347
|
});
|
|
10030
|
-
}
|
|
10031
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('duration')) {
|
|
10032
10348
|
this.accumulableControl.addEventListener('accumulable-control-duration', event => {
|
|
10033
|
-
|
|
10034
|
-
this.rdkTask.duration = event.detail.duration;
|
|
10035
|
-
this.rdkTask.wait = event.detail.duration;
|
|
10036
|
-
this.rdkTask.iti = event.detail.duration;
|
|
10037
|
-
}
|
|
10349
|
+
this.duration = event.detail.duration;
|
|
10038
10350
|
});
|
|
10039
|
-
}
|
|
10040
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('coherence')) {
|
|
10041
10351
|
this.accumulableControl.addEventListener('accumulable-control-coherence', event => {
|
|
10042
|
-
|
|
10043
|
-
this.rdkTask.coherence = event.detail.coherence;
|
|
10044
|
-
}
|
|
10352
|
+
this.coherence = event.detail.coherence;
|
|
10045
10353
|
});
|
|
10046
|
-
}
|
|
10047
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('color')) {
|
|
10048
10354
|
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10049
|
-
|
|
10050
|
-
this.accumulableTable.color = event.detail.color;
|
|
10051
|
-
}
|
|
10355
|
+
this.color = event.detail.color;
|
|
10052
10356
|
});
|
|
10053
|
-
}
|
|
10054
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('run')) {
|
|
10055
10357
|
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10056
10358
|
) => {
|
|
10057
10359
|
if (this.rdkTask) {
|
|
10058
10360
|
this.rdkTask.running = true;
|
|
10059
10361
|
}
|
|
10060
10362
|
});
|
|
10061
|
-
}
|
|
10062
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('pause')) {
|
|
10063
10363
|
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10064
10364
|
) => {
|
|
10065
10365
|
if (this.rdkTask) {
|
|
10066
10366
|
this.rdkTask.running = false;
|
|
10067
10367
|
}
|
|
10068
10368
|
});
|
|
10069
|
-
}
|
|
10070
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('reset')) {
|
|
10071
10369
|
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10072
10370
|
) => {
|
|
10073
10371
|
if (this.rdkTask) {
|
|
@@ -10100,11 +10398,6 @@
|
|
|
10100
10398
|
}
|
|
10101
10399
|
});
|
|
10102
10400
|
}
|
|
10103
|
-
if (this.rdkTask) {
|
|
10104
|
-
if (this.accumulableResponse) {
|
|
10105
|
-
this.accumulableResponse.trialTotal = this.rdkTask.trials;
|
|
10106
|
-
}
|
|
10107
|
-
}
|
|
10108
10401
|
if (this.rdkTask) {
|
|
10109
10402
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
10110
10403
|
if (this.accumulableResponse) {
|
|
@@ -10130,18 +10423,7 @@
|
|
|
10130
10423
|
}
|
|
10131
10424
|
if (this.accumulableResponse) {
|
|
10132
10425
|
this.accumulableResponse.addEventListener('accumulable-response', event => {
|
|
10133
|
-
|
|
10134
|
-
this.accumulableTable.correctCount = event.detail.correctCount;
|
|
10135
|
-
this.accumulableTable.errorCount = event.detail.errorCount;
|
|
10136
|
-
this.accumulableTable.nrCount = event.detail.nrCount;
|
|
10137
|
-
this.accumulableTable.accuracy = event.detail.accuracy;
|
|
10138
|
-
this.accumulableTable.correctMeanRT = event.detail.correctMeanRT;
|
|
10139
|
-
this.accumulableTable.errorMeanRT = event.detail.errorMeanRT;
|
|
10140
|
-
this.accumulableTable.meanRT = event.detail.meanRT;
|
|
10141
|
-
this.accumulableTable.correctSDRT = event.detail.correctSDRT;
|
|
10142
|
-
this.accumulableTable.errorSDRT = event.detail.errorSDRT;
|
|
10143
|
-
this.accumulableTable.sdRT = event.detail.sdRT;
|
|
10144
|
-
}
|
|
10426
|
+
this.data = event.detail.data;
|
|
10145
10427
|
if (this.ddmModel) {
|
|
10146
10428
|
this.ddmModel.trial({
|
|
10147
10429
|
index: event.detail.trial,
|
|
@@ -10151,34 +10433,73 @@
|
|
|
10151
10433
|
}
|
|
10152
10434
|
if (this.ddmFit) {
|
|
10153
10435
|
this.ddmFit.set({
|
|
10154
|
-
accuracy: event.detail.accuracy,
|
|
10155
|
-
correctMeanRT: event.detail.correctMeanRT,
|
|
10156
|
-
errorMeanRT: event.detail.errorMeanRT,
|
|
10157
|
-
meanRT: event.detail.meanRT,
|
|
10158
|
-
correctSDRT: event.detail.correctSDRT,
|
|
10159
|
-
errorSDRT: event.detail.errorSDRT,
|
|
10160
|
-
sdRT: event.detail.sdRT
|
|
10436
|
+
accuracy: event.detail.data.accuracy,
|
|
10437
|
+
correctMeanRT: event.detail.data.correctMeanRT,
|
|
10438
|
+
errorMeanRT: event.detail.data.errorMeanRT,
|
|
10439
|
+
meanRT: event.detail.data.meanRT,
|
|
10440
|
+
correctSDRT: event.detail.data.correctSDRT,
|
|
10441
|
+
errorSDRT: event.detail.data.errorSDRT,
|
|
10442
|
+
sdRT: event.detail.data.sdRT
|
|
10161
10443
|
});
|
|
10162
10444
|
}
|
|
10445
|
+
this.requestUpdate();
|
|
10163
10446
|
});
|
|
10164
10447
|
}
|
|
10165
10448
|
if (this.ddmFit) {
|
|
10166
10449
|
this.ddmFit.addEventListener('ddm-fit-update', event => {
|
|
10167
|
-
|
|
10168
|
-
|
|
10169
|
-
|
|
10170
|
-
|
|
10171
|
-
this.ddmParameters.t0 = event.detail.t0;
|
|
10172
|
-
}
|
|
10173
|
-
if (this.ddmModel) {
|
|
10174
|
-
this.ddmModel.a = event.detail.a;
|
|
10175
|
-
this.ddmModel.z = 0.5; // event.detail.z;
|
|
10176
|
-
this.ddmModel.v = event.detail.v;
|
|
10177
|
-
this.ddmModel.t0 = event.detail.t0;
|
|
10178
|
-
}
|
|
10450
|
+
this.a = event.detail.a;
|
|
10451
|
+
this.z = 0.5; // event.detail.z;
|
|
10452
|
+
this.v = event.detail.v;
|
|
10453
|
+
this.t0 = event.detail.t0;
|
|
10179
10454
|
});
|
|
10180
10455
|
}
|
|
10181
10456
|
}
|
|
10457
|
+
update(changedProperties) {
|
|
10458
|
+
super.update(changedProperties);
|
|
10459
|
+
if (this.accumulableControl) {
|
|
10460
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10461
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10462
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10463
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10464
|
+
}
|
|
10465
|
+
if (this.rdkTask) {
|
|
10466
|
+
this.rdkTask.trials = this.trials;
|
|
10467
|
+
this.rdkTask.duration = this.duration;
|
|
10468
|
+
this.rdkTask.wait = this.duration;
|
|
10469
|
+
this.rdkTask.iti = this.duration;
|
|
10470
|
+
this.rdkTask.coherence = this.coherence;
|
|
10471
|
+
}
|
|
10472
|
+
if (this.ddmParameters) {
|
|
10473
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10474
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10475
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10476
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10477
|
+
}
|
|
10478
|
+
if (this.ddmModel) {
|
|
10479
|
+
this.ddmModel.a = +this.a;
|
|
10480
|
+
this.ddmModel.z = +this.z;
|
|
10481
|
+
this.ddmModel.v = +this.v;
|
|
10482
|
+
this.ddmModel.t0 = +this.t0;
|
|
10483
|
+
}
|
|
10484
|
+
if (this.accumulableResponse) {
|
|
10485
|
+
this.accumulableResponse.trialTotal = this.trials;
|
|
10486
|
+
}
|
|
10487
|
+
if (this.accumulableTable) {
|
|
10488
|
+
this.accumulableTable.color = this.color;
|
|
10489
|
+
}
|
|
10490
|
+
if (this.accumulableTable && this.data) {
|
|
10491
|
+
this.accumulableTable.correctCount = this.data.correctCount;
|
|
10492
|
+
this.accumulableTable.errorCount = this.data.errorCount;
|
|
10493
|
+
this.accumulableTable.nrCount = this.data.nrCount;
|
|
10494
|
+
this.accumulableTable.accuracy = this.data.accuracy;
|
|
10495
|
+
this.accumulableTable.correctMeanRT = this.data.correctMeanRT;
|
|
10496
|
+
this.accumulableTable.errorMeanRT = this.data.errorMeanRT;
|
|
10497
|
+
this.accumulableTable.meanRT = this.data.meanRT;
|
|
10498
|
+
this.accumulableTable.correctSDRT = this.data.correctSDRT;
|
|
10499
|
+
this.accumulableTable.errorSDRT = this.data.errorSDRT;
|
|
10500
|
+
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10501
|
+
}
|
|
10502
|
+
}
|
|
10182
10503
|
}
|
|
10183
10504
|
customElements.define('ddm-example-human', DDMExampleHuman);
|
|
10184
10505
|
|
|
@@ -10194,6 +10515,11 @@
|
|
|
10194
10515
|
type: Number,
|
|
10195
10516
|
reflect: true
|
|
10196
10517
|
},
|
|
10518
|
+
color: {
|
|
10519
|
+
attribute: 'color',
|
|
10520
|
+
type: String,
|
|
10521
|
+
reflect: true
|
|
10522
|
+
},
|
|
10197
10523
|
a: {
|
|
10198
10524
|
attribute: 'boundary-separation',
|
|
10199
10525
|
type: Number,
|
|
@@ -10219,10 +10545,12 @@
|
|
|
10219
10545
|
constructor() {
|
|
10220
10546
|
super();
|
|
10221
10547
|
this.trials = 10;
|
|
10222
|
-
this.
|
|
10223
|
-
this.
|
|
10224
|
-
this.
|
|
10225
|
-
this.
|
|
10548
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10549
|
+
this.color = 'outcome';
|
|
10550
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10551
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10552
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10553
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10226
10554
|
this.accumulableControl = null;
|
|
10227
10555
|
this.accumulableTable = null;
|
|
10228
10556
|
this.ddmParameters = null;
|
|
@@ -10245,6 +10573,9 @@
|
|
|
10245
10573
|
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10246
10574
|
this.trials = event.detail.trials;
|
|
10247
10575
|
});
|
|
10576
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10577
|
+
this.color = event.detail.color;
|
|
10578
|
+
});
|
|
10248
10579
|
}
|
|
10249
10580
|
if (this.ddmParameters) {
|
|
10250
10581
|
this.ddmParameters.addEventListener('ddm-parameters-a', event => {
|
|
@@ -10284,7 +10615,11 @@
|
|
|
10284
10615
|
update(changedProperties) {
|
|
10285
10616
|
super.update(changedProperties);
|
|
10286
10617
|
if (this.accumulableControl) {
|
|
10287
|
-
this.accumulableControl.trials = this.trials;
|
|
10618
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10619
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10620
|
+
}
|
|
10621
|
+
if (this.accumulableTable) {
|
|
10622
|
+
this.accumulableTable.color = this.color;
|
|
10288
10623
|
}
|
|
10289
10624
|
if (this.accumulableTable && this.data) {
|
|
10290
10625
|
this.accumulableTable.correctCount = this.data.correctCount;
|
|
@@ -10299,10 +10634,10 @@
|
|
|
10299
10634
|
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10300
10635
|
}
|
|
10301
10636
|
if (this.ddmParameters) {
|
|
10302
|
-
this.ddmParameters.a = this.a;
|
|
10303
|
-
this.ddmParameters.z = this.z;
|
|
10304
|
-
this.ddmParameters.v = this.v;
|
|
10305
|
-
this.ddmParameters.t0 = this.t0;
|
|
10637
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10638
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10639
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10640
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10306
10641
|
}
|
|
10307
10642
|
if (this.ddmModel) {
|
|
10308
10643
|
this.ddmModel.trials = this.trials;
|
|
@@ -10315,9 +10650,6 @@
|
|
|
10315
10650
|
}
|
|
10316
10651
|
customElements.define('ddm-example-interactive', DDMExampleInteractive);
|
|
10317
10652
|
|
|
10318
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
10319
|
-
|
|
10320
|
-
|
|
10321
10653
|
/*
|
|
10322
10654
|
DDMExampleModel element
|
|
10323
10655
|
<ddm-example-model>
|
|
@@ -10374,10 +10706,10 @@
|
|
|
10374
10706
|
this.coherence = 0.5;
|
|
10375
10707
|
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10376
10708
|
this.color = 'outcome';
|
|
10377
|
-
this.a =
|
|
10378
|
-
this.z =
|
|
10379
|
-
this.v =
|
|
10380
|
-
this.t0 =
|
|
10709
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10710
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10711
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10712
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10381
10713
|
this.accumulableControl = null;
|
|
10382
10714
|
this.rdkTask = null;
|
|
10383
10715
|
this.ddmParameters = null;
|
|
@@ -10399,60 +10731,48 @@
|
|
|
10399
10731
|
this.accumulableResponse = this.querySelector('accumulable-response');
|
|
10400
10732
|
this.accumulableTable = this.querySelector('accumulable-table');
|
|
10401
10733
|
if (this.accumulableControl) {
|
|
10402
|
-
|
|
10403
|
-
this.
|
|
10404
|
-
|
|
10405
|
-
|
|
10406
|
-
|
|
10407
|
-
|
|
10408
|
-
|
|
10409
|
-
|
|
10410
|
-
|
|
10411
|
-
|
|
10412
|
-
|
|
10413
|
-
this.
|
|
10414
|
-
this.
|
|
10415
|
-
}
|
|
10416
|
-
|
|
10417
|
-
|
|
10418
|
-
|
|
10419
|
-
|
|
10420
|
-
|
|
10421
|
-
|
|
10422
|
-
|
|
10423
|
-
|
|
10424
|
-
|
|
10425
|
-
|
|
10426
|
-
|
|
10427
|
-
|
|
10428
|
-
|
|
10429
|
-
|
|
10430
|
-
|
|
10431
|
-
|
|
10432
|
-
|
|
10433
|
-
|
|
10434
|
-
|
|
10435
|
-
|
|
10436
|
-
|
|
10437
|
-
|
|
10438
|
-
|
|
10439
|
-
|
|
10440
|
-
|
|
10441
|
-
|
|
10442
|
-
|
|
10443
|
-
|
|
10444
|
-
if (this.rdkTask) {
|
|
10445
|
-
this.rdkTask.reset();
|
|
10446
|
-
}
|
|
10447
|
-
if (this.ddmModel) {
|
|
10448
|
-
this.ddmModel.trials = this.trialCount;
|
|
10449
|
-
}
|
|
10450
|
-
if (this.accumulableResponse) {
|
|
10451
|
-
this.accumulableResponse.reset();
|
|
10452
|
-
}
|
|
10453
|
-
if (this.accumulableTable) ;
|
|
10454
|
-
});
|
|
10455
|
-
}
|
|
10734
|
+
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10735
|
+
this.trials = event.detail.trials;
|
|
10736
|
+
});
|
|
10737
|
+
this.accumulableControl.addEventListener('accumulable-control-duration', event => {
|
|
10738
|
+
this.duration = event.detail.duration;
|
|
10739
|
+
});
|
|
10740
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10741
|
+
this.color = event.detail.color;
|
|
10742
|
+
});
|
|
10743
|
+
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10744
|
+
) => {
|
|
10745
|
+
if (this.rdkTask) {
|
|
10746
|
+
this.rdkTask.running = true;
|
|
10747
|
+
}
|
|
10748
|
+
if (this.ddmModel) {
|
|
10749
|
+
this.ddmModel.resumeTrial();
|
|
10750
|
+
}
|
|
10751
|
+
});
|
|
10752
|
+
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10753
|
+
) => {
|
|
10754
|
+
if (this.rdkTask) {
|
|
10755
|
+
this.rdkTask.running = false;
|
|
10756
|
+
}
|
|
10757
|
+
if (this.ddmModel) {
|
|
10758
|
+
this.ddmModel.pauseTrial();
|
|
10759
|
+
}
|
|
10760
|
+
});
|
|
10761
|
+
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10762
|
+
) => {
|
|
10763
|
+
this.trialCount = 0;
|
|
10764
|
+
this.signal = undefined;
|
|
10765
|
+
if (this.rdkTask) {
|
|
10766
|
+
this.rdkTask.reset();
|
|
10767
|
+
}
|
|
10768
|
+
if (this.ddmModel) {
|
|
10769
|
+
this.ddmModel.trials = this.trialCount;
|
|
10770
|
+
}
|
|
10771
|
+
if (this.accumulableResponse) {
|
|
10772
|
+
this.accumulableResponse.reset();
|
|
10773
|
+
}
|
|
10774
|
+
if (this.accumulableTable) ;
|
|
10775
|
+
});
|
|
10456
10776
|
}
|
|
10457
10777
|
if (this.rdkTask) {
|
|
10458
10778
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
@@ -10511,17 +10831,15 @@
|
|
|
10511
10831
|
this.model = event.detail.model;
|
|
10512
10832
|
this.requestUpdate();
|
|
10513
10833
|
});
|
|
10514
|
-
|
|
10515
|
-
this.
|
|
10516
|
-
|
|
10517
|
-
|
|
10518
|
-
|
|
10519
|
-
|
|
10520
|
-
|
|
10521
|
-
|
|
10522
|
-
|
|
10523
|
-
});
|
|
10524
|
-
}
|
|
10834
|
+
this.ddmModel.addEventListener('accumulable-response', event => {
|
|
10835
|
+
if (this.accumulableResponse) {
|
|
10836
|
+
const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
|
|
10837
|
+
this.accumulableResponse.responded(response);
|
|
10838
|
+
}
|
|
10839
|
+
this.data = event.detail.data;
|
|
10840
|
+
this.model = event.detail.model;
|
|
10841
|
+
this.requestUpdate();
|
|
10842
|
+
});
|
|
10525
10843
|
}
|
|
10526
10844
|
this.requestUpdate();
|
|
10527
10845
|
}
|
|
@@ -10531,10 +10849,10 @@
|
|
|
10531
10849
|
this.trialCount = this.trials;
|
|
10532
10850
|
}
|
|
10533
10851
|
if (this.accumulableControl) {
|
|
10534
|
-
this.accumulableControl.trials = this.trials;
|
|
10535
|
-
this.accumulableControl.duration = this.duration;
|
|
10536
|
-
this.accumulableControl.coherence = this.coherence;
|
|
10537
|
-
this.accumulableControl.color = this.color;
|
|
10852
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10853
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10854
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10855
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10538
10856
|
}
|
|
10539
10857
|
if (this.rdkTask) {
|
|
10540
10858
|
this.rdkTask.trials = this.trials;
|
|
@@ -10542,10 +10860,10 @@
|
|
|
10542
10860
|
this.rdkTask.coherence = this.coherence;
|
|
10543
10861
|
}
|
|
10544
10862
|
if (this.ddmParameters) {
|
|
10545
|
-
this.ddmParameters.a = this.a;
|
|
10546
|
-
this.ddmParameters.z = this.z;
|
|
10547
|
-
this.ddmParameters.v = this.v;
|
|
10548
|
-
this.ddmParameters.t0 = this.t0;
|
|
10863
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10864
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10865
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10866
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10549
10867
|
}
|
|
10550
10868
|
if (this.ddmModel) {
|
|
10551
10869
|
this.ddmModel.trials = this.trialCount;
|