@decidables/accumulable-elements 0.1.2 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +28 -0
- package/README.md +72 -33
- package/lib/accumulableElements.esm.js +747 -442
- package/lib/accumulableElements.esm.js.map +1 -1
- package/lib/accumulableElements.esm.min.js +298 -121
- package/lib/accumulableElements.esm.min.js.map +1 -1
- package/lib/accumulableElements.umd.js +747 -442
- package/lib/accumulableElements.umd.js.map +1 -1
- package/lib/accumulableElements.umd.min.js +298 -121
- package/lib/accumulableElements.umd.min.js.map +1 -1
- package/package.json +6 -6
- 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
|
@@ -4,20 +4,20 @@
|
|
|
4
4
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
5
5
|
*/
|
|
6
6
|
const t$1 = globalThis,
|
|
7
|
-
e$2 = t$1.ShadowRoot && (
|
|
8
|
-
s$
|
|
7
|
+
e$2 = t$1.ShadowRoot && (undefined === t$1.ShadyCSS || t$1.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
|
|
8
|
+
s$1 = Symbol(),
|
|
9
9
|
o$3 = new WeakMap();
|
|
10
10
|
let n$2 = class n {
|
|
11
11
|
constructor(t, e, o) {
|
|
12
|
-
if (this._$cssResult$ =
|
|
12
|
+
if (this._$cssResult$ = true, o !== s$1) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
|
|
13
13
|
this.cssText = t, this.t = e;
|
|
14
14
|
}
|
|
15
15
|
get styleSheet() {
|
|
16
16
|
let t = this.o;
|
|
17
17
|
const s = this.t;
|
|
18
|
-
if (e$2 &&
|
|
19
|
-
const e =
|
|
20
|
-
e && (t = o$3.get(s)),
|
|
18
|
+
if (e$2 && undefined === t) {
|
|
19
|
+
const e = undefined !== s && 1 === s.length;
|
|
20
|
+
e && (t = o$3.get(s)), undefined === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$3.set(s, t));
|
|
21
21
|
}
|
|
22
22
|
return t;
|
|
23
23
|
}
|
|
@@ -25,20 +25,20 @@ let n$2 = class n {
|
|
|
25
25
|
return this.cssText;
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
-
const r$3 = t => new n$2("string" == typeof t ? t : t + "",
|
|
29
|
-
i$
|
|
28
|
+
const r$3 = t => new n$2("string" == typeof t ? t : t + "", undefined, s$1),
|
|
29
|
+
i$3 = (t, ...e) => {
|
|
30
30
|
const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
|
|
31
|
-
if (
|
|
31
|
+
if (true === t._$cssResult$) return t.cssText;
|
|
32
32
|
if ("number" == typeof t) return t;
|
|
33
33
|
throw Error("Value passed to 'css' function must be a 'css' function result: " + t + ". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.");
|
|
34
34
|
})(s) + t[o + 1], t[0]);
|
|
35
|
-
return new n$2(o, t, s$
|
|
35
|
+
return new n$2(o, t, s$1);
|
|
36
36
|
},
|
|
37
37
|
S$1 = (s, o) => {
|
|
38
38
|
if (e$2) s.adoptedStyleSheets = o.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet);else for (const e of o) {
|
|
39
39
|
const o = document.createElement("style"),
|
|
40
40
|
n = t$1.litNonce;
|
|
41
|
-
|
|
41
|
+
undefined !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
|
|
42
42
|
}
|
|
43
43
|
},
|
|
44
44
|
c$2 = e$2 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
|
|
@@ -53,7 +53,7 @@ const r$3 = t => new n$2("string" == typeof t ? t : t + "", void 0, s$2),
|
|
|
53
53
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
54
54
|
*/
|
|
55
55
|
const {
|
|
56
|
-
is: i$
|
|
56
|
+
is: i$2,
|
|
57
57
|
defineProperty: e$1,
|
|
58
58
|
getOwnPropertyDescriptor: r$2,
|
|
59
59
|
getOwnPropertyNames: h$1,
|
|
@@ -97,12 +97,12 @@ const {
|
|
|
97
97
|
return i;
|
|
98
98
|
}
|
|
99
99
|
},
|
|
100
|
-
f$1 = (t, s) => !i$
|
|
100
|
+
f$1 = (t, s) => !i$2(t, s),
|
|
101
101
|
y$2 = {
|
|
102
|
-
attribute:
|
|
102
|
+
attribute: true,
|
|
103
103
|
type: String,
|
|
104
104
|
converter: u$1,
|
|
105
|
-
reflect:
|
|
105
|
+
reflect: false,
|
|
106
106
|
hasChanged: f$1
|
|
107
107
|
};
|
|
108
108
|
Symbol.metadata ??= Symbol("metadata"), a$1.litPropertyMetadata ??= new WeakMap();
|
|
@@ -114,10 +114,10 @@ let b$1 = class b extends HTMLElement {
|
|
|
114
114
|
return this.finalize(), this._$Eh && [...this._$Eh.keys()];
|
|
115
115
|
}
|
|
116
116
|
static createProperty(t, s = y$2) {
|
|
117
|
-
if (s.state && (s.attribute =
|
|
117
|
+
if (s.state && (s.attribute = false), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
|
|
118
118
|
const i = Symbol(),
|
|
119
119
|
r = this.getPropertyDescriptor(t, i, s);
|
|
120
|
-
|
|
120
|
+
undefined !== r && e$1(this.prototype, t, r);
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
123
|
static getPropertyDescriptor(t, s, i) {
|
|
@@ -140,8 +140,8 @@ let b$1 = class b extends HTMLElement {
|
|
|
140
140
|
const r = e?.call(this);
|
|
141
141
|
h.call(this, s), this.requestUpdate(t, r, i);
|
|
142
142
|
},
|
|
143
|
-
configurable:
|
|
144
|
-
enumerable:
|
|
143
|
+
configurable: true,
|
|
144
|
+
enumerable: true
|
|
145
145
|
};
|
|
146
146
|
}
|
|
147
147
|
static getPropertyOptions(t) {
|
|
@@ -150,11 +150,11 @@ let b$1 = class b extends HTMLElement {
|
|
|
150
150
|
static _$Ei() {
|
|
151
151
|
if (this.hasOwnProperty(d$1("elementProperties"))) return;
|
|
152
152
|
const t = n$1(this);
|
|
153
|
-
t.finalize(),
|
|
153
|
+
t.finalize(), undefined !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
|
|
154
154
|
}
|
|
155
155
|
static finalize() {
|
|
156
156
|
if (this.hasOwnProperty(d$1("finalized"))) return;
|
|
157
|
-
if (this.finalized =
|
|
157
|
+
if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
|
|
158
158
|
const t = this.properties,
|
|
159
159
|
s = [...h$1(t), ...o$2(t)];
|
|
160
160
|
for (const i of s) this.createProperty(i, t[i]);
|
|
@@ -162,12 +162,12 @@ let b$1 = class b extends HTMLElement {
|
|
|
162
162
|
const t = this[Symbol.metadata];
|
|
163
163
|
if (null !== t) {
|
|
164
164
|
const s = litPropertyMetadata.get(t);
|
|
165
|
-
if (
|
|
165
|
+
if (undefined !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
|
|
166
166
|
}
|
|
167
167
|
this._$Eh = new Map();
|
|
168
168
|
for (const [t, s] of this.elementProperties) {
|
|
169
169
|
const i = this._$Eu(t, s);
|
|
170
|
-
|
|
170
|
+
undefined !== i && this._$Eh.set(i, t);
|
|
171
171
|
}
|
|
172
172
|
this.elementStyles = this.finalizeStyles(this.styles);
|
|
173
173
|
}
|
|
@@ -176,21 +176,21 @@ let b$1 = class b extends HTMLElement {
|
|
|
176
176
|
if (Array.isArray(s)) {
|
|
177
177
|
const e = new Set(s.flat(1 / 0).reverse());
|
|
178
178
|
for (const s of e) i.unshift(c$2(s));
|
|
179
|
-
} else
|
|
179
|
+
} else undefined !== s && i.push(c$2(s));
|
|
180
180
|
return i;
|
|
181
181
|
}
|
|
182
182
|
static _$Eu(t, s) {
|
|
183
183
|
const i = s.attribute;
|
|
184
|
-
return
|
|
184
|
+
return false === i ? undefined : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : undefined;
|
|
185
185
|
}
|
|
186
186
|
constructor() {
|
|
187
|
-
super(), this._$Ep =
|
|
187
|
+
super(), this._$Ep = undefined, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
|
|
188
188
|
}
|
|
189
189
|
_$Ev() {
|
|
190
190
|
this._$ES = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
|
|
191
191
|
}
|
|
192
192
|
addController(t) {
|
|
193
|
-
(this._$EO ??= new Set()).add(t),
|
|
193
|
+
(this._$EO ??= new Set()).add(t), undefined !== this.renderRoot && this.isConnected && t.hostConnected?.();
|
|
194
194
|
}
|
|
195
195
|
removeController(t) {
|
|
196
196
|
this._$EO?.delete(t);
|
|
@@ -206,7 +206,7 @@ let b$1 = class b extends HTMLElement {
|
|
|
206
206
|
return S$1(t, this.constructor.elementStyles), t;
|
|
207
207
|
}
|
|
208
208
|
connectedCallback() {
|
|
209
|
-
this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(
|
|
209
|
+
this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(true), this._$EO?.forEach(t => t.hostConnected?.());
|
|
210
210
|
}
|
|
211
211
|
enableUpdating(t) {}
|
|
212
212
|
disconnectedCallback() {
|
|
@@ -218,34 +218,34 @@ let b$1 = class b extends HTMLElement {
|
|
|
218
218
|
_$EC(t, s) {
|
|
219
219
|
const i = this.constructor.elementProperties.get(t),
|
|
220
220
|
e = this.constructor._$Eu(t, i);
|
|
221
|
-
if (
|
|
222
|
-
const r = (
|
|
221
|
+
if (undefined !== e && true === i.reflect) {
|
|
222
|
+
const r = (undefined !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
|
|
223
223
|
this._$Em = t, null == r ? this.removeAttribute(e) : this.setAttribute(e, r), this._$Em = null;
|
|
224
224
|
}
|
|
225
225
|
}
|
|
226
226
|
_$AK(t, s) {
|
|
227
227
|
const i = this.constructor,
|
|
228
228
|
e = i._$Eh.get(t);
|
|
229
|
-
if (
|
|
229
|
+
if (undefined !== e && this._$Em !== e) {
|
|
230
230
|
const t = i.getPropertyOptions(e),
|
|
231
231
|
r = "function" == typeof t.converter ? {
|
|
232
232
|
fromAttribute: t.converter
|
|
233
|
-
} :
|
|
233
|
+
} : undefined !== t.converter?.fromAttribute ? t.converter : u$1;
|
|
234
234
|
this._$Em = e, this[e] = r.fromAttribute(s, t.type), this._$Em = null;
|
|
235
235
|
}
|
|
236
236
|
}
|
|
237
237
|
requestUpdate(t, s, i) {
|
|
238
|
-
if (
|
|
238
|
+
if (undefined !== t) {
|
|
239
239
|
if (i ??= this.constructor.getPropertyOptions(t), !(i.hasChanged ?? f$1)(this[t], s)) return;
|
|
240
240
|
this.P(t, s, i);
|
|
241
241
|
}
|
|
242
|
-
|
|
242
|
+
false === this.isUpdatePending && (this._$ES = this._$ET());
|
|
243
243
|
}
|
|
244
244
|
P(t, s, i) {
|
|
245
|
-
this._$AL.has(t) || this._$AL.set(t, s),
|
|
245
|
+
this._$AL.has(t) || this._$AL.set(t, s), true === i.reflect && this._$Em !== t && (this._$Ej ??= new Set()).add(t);
|
|
246
246
|
}
|
|
247
247
|
async _$ET() {
|
|
248
|
-
this.isUpdatePending =
|
|
248
|
+
this.isUpdatePending = true;
|
|
249
249
|
try {
|
|
250
250
|
await this._$ES;
|
|
251
251
|
} catch (t) {
|
|
@@ -262,26 +262,26 @@ let b$1 = class b extends HTMLElement {
|
|
|
262
262
|
if (!this.hasUpdated) {
|
|
263
263
|
if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
|
|
264
264
|
for (const [t, s] of this._$Ep) this[t] = s;
|
|
265
|
-
this._$Ep =
|
|
265
|
+
this._$Ep = undefined;
|
|
266
266
|
}
|
|
267
267
|
const t = this.constructor.elementProperties;
|
|
268
|
-
if (t.size > 0) for (const [s, i] of t)
|
|
268
|
+
if (t.size > 0) for (const [s, i] of t) true !== i.wrapped || this._$AL.has(s) || undefined === this[s] || this.P(s, this[s], i);
|
|
269
269
|
}
|
|
270
|
-
let t =
|
|
270
|
+
let t = false;
|
|
271
271
|
const s = this._$AL;
|
|
272
272
|
try {
|
|
273
273
|
t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EU();
|
|
274
274
|
} catch (s) {
|
|
275
|
-
throw t =
|
|
275
|
+
throw t = false, this._$EU(), s;
|
|
276
276
|
}
|
|
277
277
|
t && this._$AE(s);
|
|
278
278
|
}
|
|
279
279
|
willUpdate(t) {}
|
|
280
280
|
_$AE(t) {
|
|
281
|
-
this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated =
|
|
281
|
+
this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t)), this.updated(t);
|
|
282
282
|
}
|
|
283
283
|
_$EU() {
|
|
284
|
-
this._$AL = new Map(), this.isUpdatePending =
|
|
284
|
+
this._$AL = new Map(), this.isUpdatePending = false;
|
|
285
285
|
}
|
|
286
286
|
get updateComplete() {
|
|
287
287
|
return this.getUpdateComplete();
|
|
@@ -290,7 +290,7 @@ let b$1 = class b extends HTMLElement {
|
|
|
290
290
|
return this._$ES;
|
|
291
291
|
}
|
|
292
292
|
shouldUpdate(t) {
|
|
293
|
-
return
|
|
293
|
+
return true;
|
|
294
294
|
}
|
|
295
295
|
update(t) {
|
|
296
296
|
this._$Ej &&= this._$Ej.forEach(t => this._$EC(t, this[t])), this._$EU();
|
|
@@ -310,10 +310,10 @@ b$1.elementStyles = [], b$1.shadowRootOptions = {
|
|
|
310
310
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
311
311
|
*/
|
|
312
312
|
const t = globalThis,
|
|
313
|
-
i = t.trustedTypes,
|
|
314
|
-
s
|
|
313
|
+
i$1 = t.trustedTypes,
|
|
314
|
+
s = i$1 ? i$1.createPolicy("lit-html", {
|
|
315
315
|
createHTML: t => t
|
|
316
|
-
}) :
|
|
316
|
+
}) : undefined,
|
|
317
317
|
e = "$lit$",
|
|
318
318
|
h = `lit$${Math.random().toFixed(9).slice(2)}$`,
|
|
319
319
|
o$1 = "?" + h,
|
|
@@ -338,19 +338,19 @@ const t = globalThis,
|
|
|
338
338
|
}),
|
|
339
339
|
x$1 = y$1(1),
|
|
340
340
|
b = y$1(2),
|
|
341
|
-
|
|
342
|
-
|
|
341
|
+
T = Symbol.for("lit-noChange"),
|
|
342
|
+
E = Symbol.for("lit-nothing"),
|
|
343
343
|
A = new WeakMap(),
|
|
344
|
-
|
|
345
|
-
function
|
|
346
|
-
if (!
|
|
347
|
-
return
|
|
344
|
+
C = r$1.createTreeWalker(r$1, 129);
|
|
345
|
+
function P(t, i) {
|
|
346
|
+
if (!a(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
|
|
347
|
+
return undefined !== s ? s.createHTML(i) : i;
|
|
348
348
|
}
|
|
349
|
-
const
|
|
349
|
+
const V = (t, i) => {
|
|
350
350
|
const s = t.length - 1,
|
|
351
351
|
o = [];
|
|
352
352
|
let r,
|
|
353
|
-
l = 2 === i ? "<svg>" : "",
|
|
353
|
+
l = 2 === i ? "<svg>" : 3 === i ? "<math>" : "",
|
|
354
354
|
c = f;
|
|
355
355
|
for (let i = 0; i < s; i++) {
|
|
356
356
|
const s = t[i];
|
|
@@ -358,13 +358,13 @@ const P = (t, i) => {
|
|
|
358
358
|
u,
|
|
359
359
|
d = -1,
|
|
360
360
|
y = 0;
|
|
361
|
-
for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v :
|
|
361
|
+
for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v : undefined !== u[1] ? c = _ : undefined !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : undefined !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f, d = -1) : undefined === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = undefined === u[3] ? m : '"' === u[3] ? g : p) : c === g || c === p ? c = m : c === v || c === _ ? c = f : (c = m, r = undefined);
|
|
362
362
|
const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
|
|
363
363
|
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);
|
|
364
364
|
}
|
|
365
|
-
return [
|
|
365
|
+
return [P(t, l + (t[s] || "<?>") + (2 === i ? "</svg>" : 3 === i ? "</math>" : "")), o];
|
|
366
366
|
};
|
|
367
|
-
class
|
|
367
|
+
class N {
|
|
368
368
|
constructor({
|
|
369
369
|
strings: t,
|
|
370
370
|
_$litType$: s
|
|
@@ -375,12 +375,12 @@ class V {
|
|
|
375
375
|
a = 0;
|
|
376
376
|
const u = t.length - 1,
|
|
377
377
|
d = this.parts,
|
|
378
|
-
[f, v] =
|
|
379
|
-
if (this.el =
|
|
378
|
+
[f, v] = V(t, s);
|
|
379
|
+
if (this.el = N.createElement(f, n), C.currentNode = this.el.content, 2 === s || 3 === s) {
|
|
380
380
|
const t = this.el.content.firstChild;
|
|
381
381
|
t.replaceWith(...t.childNodes);
|
|
382
382
|
}
|
|
383
|
-
for (; null !== (r =
|
|
383
|
+
for (; null !== (r = C.nextNode()) && d.length < u;) {
|
|
384
384
|
if (1 === r.nodeType) {
|
|
385
385
|
if (r.hasAttributes()) for (const t of r.getAttributeNames()) if (t.endsWith(e)) {
|
|
386
386
|
const i = v[a++],
|
|
@@ -391,7 +391,7 @@ class V {
|
|
|
391
391
|
index: c,
|
|
392
392
|
name: e[2],
|
|
393
393
|
strings: s,
|
|
394
|
-
ctor: "." === e[1] ?
|
|
394
|
+
ctor: "." === e[1] ? H : "?" === e[1] ? I : "@" === e[1] ? L : k
|
|
395
395
|
}), r.removeAttribute(t);
|
|
396
396
|
} else t.startsWith(h) && (d.push({
|
|
397
397
|
type: 6,
|
|
@@ -401,8 +401,8 @@ class V {
|
|
|
401
401
|
const t = r.textContent.split(h),
|
|
402
402
|
s = t.length - 1;
|
|
403
403
|
if (s > 0) {
|
|
404
|
-
r.textContent = i ? i.emptyScript : "";
|
|
405
|
-
for (let i = 0; i < s; i++) r.append(t[i], l()),
|
|
404
|
+
r.textContent = i$1 ? i$1.emptyScript : "";
|
|
405
|
+
for (let i = 0; i < s; i++) r.append(t[i], l()), C.nextNode(), d.push({
|
|
406
406
|
type: 2,
|
|
407
407
|
index: ++c
|
|
408
408
|
});
|
|
@@ -427,15 +427,15 @@ class V {
|
|
|
427
427
|
return s.innerHTML = t, s;
|
|
428
428
|
}
|
|
429
429
|
}
|
|
430
|
-
function
|
|
431
|
-
if (i ===
|
|
432
|
-
let h =
|
|
433
|
-
const o = c(i) ?
|
|
434
|
-
return h?.constructor !== o && (h?._$AO?.(
|
|
430
|
+
function S(t, i, s = t, e) {
|
|
431
|
+
if (i === T) return i;
|
|
432
|
+
let h = undefined !== e ? s._$Co?.[e] : s._$Cl;
|
|
433
|
+
const o = c(i) ? undefined : i._$litDirective$;
|
|
434
|
+
return h?.constructor !== o && (h?._$AO?.(false), undefined === o ? h = undefined : (h = new o(t), h._$AT(t, s, e)), undefined !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), undefined !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
|
|
435
435
|
}
|
|
436
|
-
class
|
|
436
|
+
class M {
|
|
437
437
|
constructor(t, i) {
|
|
438
|
-
this._$AV = [], this._$AN =
|
|
438
|
+
this._$AV = [], this._$AN = undefined, this._$AD = t, this._$AM = i;
|
|
439
439
|
}
|
|
440
440
|
get parentNode() {
|
|
441
441
|
return this._$AM.parentNode;
|
|
@@ -450,37 +450,37 @@ class S {
|
|
|
450
450
|
},
|
|
451
451
|
parts: s
|
|
452
452
|
} = this._$AD,
|
|
453
|
-
e = (t?.creationScope ?? r$1).importNode(i,
|
|
454
|
-
|
|
455
|
-
let h =
|
|
453
|
+
e = (t?.creationScope ?? r$1).importNode(i, true);
|
|
454
|
+
C.currentNode = e;
|
|
455
|
+
let h = C.nextNode(),
|
|
456
456
|
o = 0,
|
|
457
457
|
n = 0,
|
|
458
458
|
l = s[0];
|
|
459
|
-
for (;
|
|
459
|
+
for (; undefined !== l;) {
|
|
460
460
|
if (o === l.index) {
|
|
461
461
|
let i;
|
|
462
|
-
2 === l.type ? i = new
|
|
462
|
+
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];
|
|
463
463
|
}
|
|
464
|
-
o !== l?.index && (h =
|
|
464
|
+
o !== l?.index && (h = C.nextNode(), o++);
|
|
465
465
|
}
|
|
466
|
-
return
|
|
466
|
+
return C.currentNode = r$1, e;
|
|
467
467
|
}
|
|
468
468
|
p(t) {
|
|
469
469
|
let i = 0;
|
|
470
|
-
for (const s of this._$AV)
|
|
470
|
+
for (const s of this._$AV) undefined !== s && (undefined !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
|
|
471
471
|
}
|
|
472
472
|
}
|
|
473
|
-
class
|
|
473
|
+
class R {
|
|
474
474
|
get _$AU() {
|
|
475
475
|
return this._$AM?._$AU ?? this._$Cv;
|
|
476
476
|
}
|
|
477
477
|
constructor(t, i, s, e) {
|
|
478
|
-
this.type = 2, this._$AH =
|
|
478
|
+
this.type = 2, this._$AH = E, this._$AN = undefined, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
|
|
479
479
|
}
|
|
480
480
|
get parentNode() {
|
|
481
481
|
let t = this._$AA.parentNode;
|
|
482
482
|
const i = this._$AM;
|
|
483
|
-
return
|
|
483
|
+
return undefined !== i && 11 === t?.nodeType && (t = i.parentNode), t;
|
|
484
484
|
}
|
|
485
485
|
get startNode() {
|
|
486
486
|
return this._$AA;
|
|
@@ -489,52 +489,52 @@ class M {
|
|
|
489
489
|
return this._$AB;
|
|
490
490
|
}
|
|
491
491
|
_$AI(t, i = this) {
|
|
492
|
-
t =
|
|
492
|
+
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) : undefined !== t._$litType$ ? this.$(t) : undefined !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
|
|
493
493
|
}
|
|
494
|
-
|
|
494
|
+
O(t) {
|
|
495
495
|
return this._$AA.parentNode.insertBefore(t, this._$AB);
|
|
496
496
|
}
|
|
497
497
|
T(t) {
|
|
498
|
-
this._$AH !== t && (this._$AR(), this._$AH = this.
|
|
498
|
+
this._$AH !== t && (this._$AR(), this._$AH = this.O(t));
|
|
499
499
|
}
|
|
500
500
|
_(t) {
|
|
501
|
-
this._$AH !==
|
|
501
|
+
this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r$1.createTextNode(t)), this._$AH = t;
|
|
502
502
|
}
|
|
503
503
|
$(t) {
|
|
504
504
|
const {
|
|
505
505
|
values: i,
|
|
506
506
|
_$litType$: s
|
|
507
507
|
} = t,
|
|
508
|
-
e = "number" == typeof s ? this._$AC(t) : (
|
|
508
|
+
e = "number" == typeof s ? this._$AC(t) : (undefined === s.el && (s.el = N.createElement(P(s.h, s.h[0]), this.options)), s);
|
|
509
509
|
if (this._$AH?._$AD === e) this._$AH.p(i);else {
|
|
510
|
-
const t = new
|
|
510
|
+
const t = new M(e, this),
|
|
511
511
|
s = t.u(this.options);
|
|
512
512
|
t.p(i), this.T(s), this._$AH = t;
|
|
513
513
|
}
|
|
514
514
|
}
|
|
515
515
|
_$AC(t) {
|
|
516
516
|
let i = A.get(t.strings);
|
|
517
|
-
return
|
|
517
|
+
return undefined === i && A.set(t.strings, i = new N(t)), i;
|
|
518
518
|
}
|
|
519
519
|
k(t) {
|
|
520
520
|
a(this._$AH) || (this._$AH = [], this._$AR());
|
|
521
521
|
const i = this._$AH;
|
|
522
522
|
let s,
|
|
523
523
|
e = 0;
|
|
524
|
-
for (const h of t) e === i.length ? i.push(s = new
|
|
524
|
+
for (const h of t) e === i.length ? i.push(s = new R(this.O(l()), this.O(l()), this, this.options)) : s = i[e], s._$AI(h), e++;
|
|
525
525
|
e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
|
|
526
526
|
}
|
|
527
527
|
_$AR(t = this._$AA.nextSibling, i) {
|
|
528
|
-
for (this._$AP?.(
|
|
528
|
+
for (this._$AP?.(false, true, i); t && t !== this._$AB;) {
|
|
529
529
|
const i = t.nextSibling;
|
|
530
530
|
t.remove(), t = i;
|
|
531
531
|
}
|
|
532
532
|
}
|
|
533
533
|
setConnected(t) {
|
|
534
|
-
|
|
534
|
+
undefined === this._$AM && (this._$Cv = t, this._$AP?.(t));
|
|
535
535
|
}
|
|
536
536
|
}
|
|
537
|
-
class
|
|
537
|
+
class k {
|
|
538
538
|
get tagName() {
|
|
539
539
|
return this.element.tagName;
|
|
540
540
|
}
|
|
@@ -542,72 +542,72 @@ class R {
|
|
|
542
542
|
return this._$AM._$AU;
|
|
543
543
|
}
|
|
544
544
|
constructor(t, i, s, e, h) {
|
|
545
|
-
this.type = 1, this._$AH =
|
|
545
|
+
this.type = 1, this._$AH = E, this._$AN = undefined, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E;
|
|
546
546
|
}
|
|
547
547
|
_$AI(t, i = this, s, e) {
|
|
548
548
|
const h = this.strings;
|
|
549
|
-
let o =
|
|
550
|
-
if (
|
|
549
|
+
let o = false;
|
|
550
|
+
if (undefined === h) t = S(this, t, i, 0), o = !c(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
|
|
551
551
|
const e = t;
|
|
552
552
|
let n, r;
|
|
553
|
-
for (t = h[0], n = 0; n < h.length - 1; n++) r =
|
|
553
|
+
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;
|
|
554
554
|
}
|
|
555
555
|
o && !e && this.j(t);
|
|
556
556
|
}
|
|
557
557
|
j(t) {
|
|
558
|
-
t ===
|
|
558
|
+
t === E ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
|
|
559
559
|
}
|
|
560
560
|
}
|
|
561
|
-
class
|
|
561
|
+
class H extends k {
|
|
562
562
|
constructor() {
|
|
563
563
|
super(...arguments), this.type = 3;
|
|
564
564
|
}
|
|
565
565
|
j(t) {
|
|
566
|
-
this.element[this.name] = t ===
|
|
566
|
+
this.element[this.name] = t === E ? undefined : t;
|
|
567
567
|
}
|
|
568
568
|
}
|
|
569
|
-
class
|
|
569
|
+
class I extends k {
|
|
570
570
|
constructor() {
|
|
571
571
|
super(...arguments), this.type = 4;
|
|
572
572
|
}
|
|
573
573
|
j(t) {
|
|
574
|
-
this.element.toggleAttribute(this.name, !!t && t !==
|
|
574
|
+
this.element.toggleAttribute(this.name, !!t && t !== E);
|
|
575
575
|
}
|
|
576
576
|
}
|
|
577
|
-
class
|
|
577
|
+
class L extends k {
|
|
578
578
|
constructor(t, i, s, e, h) {
|
|
579
579
|
super(t, i, s, e, h), this.type = 5;
|
|
580
580
|
}
|
|
581
581
|
_$AI(t, i = this) {
|
|
582
|
-
if ((t =
|
|
582
|
+
if ((t = S(this, t, i, 0) ?? E) === T) return;
|
|
583
583
|
const s = this._$AH,
|
|
584
|
-
e = t ===
|
|
585
|
-
h = t !==
|
|
584
|
+
e = t === E && s !== E || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive,
|
|
585
|
+
h = t !== E && (s === E || e);
|
|
586
586
|
e && this.element.removeEventListener(this.name, this, s), h && this.element.addEventListener(this.name, this, t), this._$AH = t;
|
|
587
587
|
}
|
|
588
588
|
handleEvent(t) {
|
|
589
589
|
"function" == typeof this._$AH ? this._$AH.call(this.options?.host ?? this.element, t) : this._$AH.handleEvent(t);
|
|
590
590
|
}
|
|
591
591
|
}
|
|
592
|
-
class
|
|
592
|
+
class z {
|
|
593
593
|
constructor(t, i, s) {
|
|
594
|
-
this.element = t, this.type = 6, this._$AN =
|
|
594
|
+
this.element = t, this.type = 6, this._$AN = undefined, this._$AM = i, this.options = s;
|
|
595
595
|
}
|
|
596
596
|
get _$AU() {
|
|
597
597
|
return this._$AM._$AU;
|
|
598
598
|
}
|
|
599
599
|
_$AI(t) {
|
|
600
|
-
|
|
600
|
+
S(this, t);
|
|
601
601
|
}
|
|
602
602
|
}
|
|
603
|
-
const
|
|
604
|
-
|
|
605
|
-
const
|
|
603
|
+
const j = t.litHtmlPolyfillSupport;
|
|
604
|
+
j?.(N, R), (t.litHtmlVersions ??= []).push("3.2.1");
|
|
605
|
+
const B = (t, i, s) => {
|
|
606
606
|
const e = s?.renderBefore ?? i;
|
|
607
607
|
let h = e._$litPart$;
|
|
608
|
-
if (
|
|
608
|
+
if (undefined === h) {
|
|
609
609
|
const t = s?.renderBefore ?? null;
|
|
610
|
-
e._$litPart$ = h = new
|
|
610
|
+
e._$litPart$ = h = new R(i.insertBefore(l(), t), t, undefined, s ?? {});
|
|
611
611
|
}
|
|
612
612
|
return h._$AI(t), h;
|
|
613
613
|
};
|
|
@@ -617,38 +617,38 @@ const j = (t, i, s) => {
|
|
|
617
617
|
* Copyright 2017 Google LLC
|
|
618
618
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
619
619
|
*/
|
|
620
|
-
class
|
|
620
|
+
class r extends b$1 {
|
|
621
621
|
constructor() {
|
|
622
622
|
super(...arguments), this.renderOptions = {
|
|
623
623
|
host: this
|
|
624
|
-
}, this._$Do =
|
|
624
|
+
}, this._$Do = undefined;
|
|
625
625
|
}
|
|
626
626
|
createRenderRoot() {
|
|
627
627
|
const t = super.createRenderRoot();
|
|
628
628
|
return this.renderOptions.renderBefore ??= t.firstChild, t;
|
|
629
629
|
}
|
|
630
630
|
update(t) {
|
|
631
|
-
const
|
|
632
|
-
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do =
|
|
631
|
+
const s = this.render();
|
|
632
|
+
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(s, this.renderRoot, this.renderOptions);
|
|
633
633
|
}
|
|
634
634
|
connectedCallback() {
|
|
635
|
-
super.connectedCallback(), this._$Do?.setConnected(
|
|
635
|
+
super.connectedCallback(), this._$Do?.setConnected(true);
|
|
636
636
|
}
|
|
637
637
|
disconnectedCallback() {
|
|
638
|
-
super.disconnectedCallback(), this._$Do?.setConnected(
|
|
638
|
+
super.disconnectedCallback(), this._$Do?.setConnected(false);
|
|
639
639
|
}
|
|
640
640
|
render() {
|
|
641
|
-
return
|
|
641
|
+
return T;
|
|
642
642
|
}
|
|
643
643
|
}
|
|
644
|
-
|
|
645
|
-
LitElement:
|
|
644
|
+
r._$litElement$ = true, r["finalized"] = true, globalThis.litElementHydrateSupport?.({
|
|
645
|
+
LitElement: r
|
|
646
646
|
});
|
|
647
|
-
const
|
|
648
|
-
|
|
649
|
-
LitElement:
|
|
647
|
+
const i = globalThis.litElementPolyfillSupport;
|
|
648
|
+
i?.({
|
|
649
|
+
LitElement: r
|
|
650
650
|
});
|
|
651
|
-
(globalThis.litElementVersions ??= []).push("4.
|
|
651
|
+
(globalThis.litElementVersions ??= []).push("4.1.1");
|
|
652
652
|
|
|
653
653
|
function ascending$1(a, b) {
|
|
654
654
|
return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
|
|
@@ -1888,7 +1888,7 @@ function yesdrag(view, noclick) {
|
|
|
1888
1888
|
}
|
|
1889
1889
|
}
|
|
1890
1890
|
|
|
1891
|
-
var constant$2 =
|
|
1891
|
+
var constant$2 = x => () => x;
|
|
1892
1892
|
|
|
1893
1893
|
function DragEvent(type, {
|
|
1894
1894
|
sourceEvent,
|
|
@@ -2494,7 +2494,7 @@ function hsl2rgb(h, m1, m2) {
|
|
|
2494
2494
|
return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255;
|
|
2495
2495
|
}
|
|
2496
2496
|
|
|
2497
|
-
var constant$1 =
|
|
2497
|
+
var constant$1 = x => () => x;
|
|
2498
2498
|
|
|
2499
2499
|
function linear$2(a, d) {
|
|
2500
2500
|
return function (t) {
|
|
@@ -4566,7 +4566,7 @@ Transform.prototype;
|
|
|
4566
4566
|
DecidablesElement Base Class - Not intended for instantiation!
|
|
4567
4567
|
<decidables-element>
|
|
4568
4568
|
*/
|
|
4569
|
-
class DecidablesElement extends
|
|
4569
|
+
class DecidablesElement extends r {
|
|
4570
4570
|
getComputedStyleValue(property) {
|
|
4571
4571
|
return getComputedStyle(this).getPropertyValue(property).trim();
|
|
4572
4572
|
}
|
|
@@ -4819,7 +4819,7 @@ class DecidablesElement extends s {
|
|
|
4819
4819
|
`;
|
|
4820
4820
|
}
|
|
4821
4821
|
static get styles() {
|
|
4822
|
-
return i$
|
|
4822
|
+
return i$3`
|
|
4823
4823
|
:host {
|
|
4824
4824
|
---shadow-0: var(--shadow-0, ${r$3(this.cssBoxShadow(0))});
|
|
4825
4825
|
---shadow-2: var(--shadow-2, ${r$3(this.cssBoxShadow(2))});
|
|
@@ -4897,8 +4897,11 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4897
4897
|
this.disabled = false;
|
|
4898
4898
|
}
|
|
4899
4899
|
static get styles() {
|
|
4900
|
-
return [super.styles, i$
|
|
4900
|
+
return [super.styles, i$3`
|
|
4901
4901
|
:host {
|
|
4902
|
+
---decidables-button-background-color-disabled: var(--decidables-button-background-color, var(---color-element-disabled));
|
|
4903
|
+
---decidables-button-background-color-enabled: var(--decidables-button-background-color, var(---color-element-enabled));
|
|
4904
|
+
|
|
4902
4905
|
margin: 0.25rem;
|
|
4903
4906
|
}
|
|
4904
4907
|
|
|
@@ -4918,7 +4921,7 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4918
4921
|
}
|
|
4919
4922
|
|
|
4920
4923
|
button:disabled {
|
|
4921
|
-
background-color: var(
|
|
4924
|
+
background-color: var(---decidables-button-background-color-disabled);
|
|
4922
4925
|
outline: none;
|
|
4923
4926
|
box-shadow: none;
|
|
4924
4927
|
}
|
|
@@ -4926,7 +4929,7 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4926
4929
|
button:enabled {
|
|
4927
4930
|
cursor: pointer;
|
|
4928
4931
|
|
|
4929
|
-
background-color: var(
|
|
4932
|
+
background-color: var(---decidables-button-background-color-enabled);
|
|
4930
4933
|
outline: none;
|
|
4931
4934
|
box-shadow: var(---shadow-2);
|
|
4932
4935
|
}
|
|
@@ -4967,7 +4970,7 @@ customElements.define('decidables-button', DecidablesButton);
|
|
|
4967
4970
|
* Copyright 2018 Google LLC
|
|
4968
4971
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
4969
4972
|
*/
|
|
4970
|
-
const o = o => o ??
|
|
4973
|
+
const o = o => o ?? E;
|
|
4971
4974
|
|
|
4972
4975
|
class DecidablesSlider extends DecidablesElement {
|
|
4973
4976
|
static get properties() {
|
|
@@ -4977,6 +4980,11 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
4977
4980
|
type: Boolean,
|
|
4978
4981
|
reflect: true
|
|
4979
4982
|
},
|
|
4983
|
+
scale: {
|
|
4984
|
+
attribute: 'scale',
|
|
4985
|
+
type: Boolean,
|
|
4986
|
+
reflect: true
|
|
4987
|
+
},
|
|
4980
4988
|
max: {
|
|
4981
4989
|
attribute: 'max',
|
|
4982
4990
|
type: Number,
|
|
@@ -4996,6 +5004,11 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
4996
5004
|
attribute: 'value',
|
|
4997
5005
|
type: Number,
|
|
4998
5006
|
reflect: true
|
|
5007
|
+
},
|
|
5008
|
+
nonlinear: {
|
|
5009
|
+
attribute: false,
|
|
5010
|
+
type: Boolean,
|
|
5011
|
+
reflect: false
|
|
4999
5012
|
}
|
|
5000
5013
|
};
|
|
5001
5014
|
}
|
|
@@ -5004,13 +5017,30 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5004
5017
|
|
|
5005
5018
|
// Attributes
|
|
5006
5019
|
this.disabled = false;
|
|
5020
|
+
this.scale = false;
|
|
5007
5021
|
this.max = undefined;
|
|
5008
5022
|
this.min = undefined;
|
|
5009
5023
|
this.step = undefined;
|
|
5010
5024
|
this.value = undefined;
|
|
5011
|
-
|
|
5012
|
-
|
|
5013
|
-
|
|
5025
|
+
this.nonlinear = false;
|
|
5026
|
+
|
|
5027
|
+
// Properties
|
|
5028
|
+
this.rangeMax = undefined;
|
|
5029
|
+
this.rangeMin = undefined;
|
|
5030
|
+
this.rangeStep = undefined;
|
|
5031
|
+
this.rangeValue = undefined;
|
|
5032
|
+
|
|
5033
|
+
// Transform
|
|
5034
|
+
this.toRange = undefined;
|
|
5035
|
+
this.fromRange = undefined;
|
|
5036
|
+
}
|
|
5037
|
+
nonlinearRange(nonlinear, toRange, fromRange) {
|
|
5038
|
+
this.nonlinear = nonlinear;
|
|
5039
|
+
this.toRange = nonlinear ? toRange : undefined;
|
|
5040
|
+
this.fromRange = nonlinear ? fromRange : undefined;
|
|
5041
|
+
}
|
|
5042
|
+
rangeChanged(event) {
|
|
5043
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5014
5044
|
this.dispatchEvent(new CustomEvent('change', {
|
|
5015
5045
|
detail: {
|
|
5016
5046
|
value: this.value
|
|
@@ -5018,12 +5048,25 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5018
5048
|
bubbles: true
|
|
5019
5049
|
}));
|
|
5020
5050
|
}
|
|
5021
|
-
|
|
5051
|
+
rangeInputted(event) {
|
|
5052
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5053
|
+
}
|
|
5054
|
+
spinnerInputted(event) {
|
|
5022
5055
|
this.value = event.target.value;
|
|
5023
5056
|
}
|
|
5057
|
+
willUpdate() {
|
|
5058
|
+
this.rangeMax = this.max === undefined ? undefined : this.nonlinear ? this.toRange(this.max) : this.max;
|
|
5059
|
+
this.rangeMin = this.min === undefined ? undefined : this.nonlinear ? this.toRange(this.min) : this.min;
|
|
5060
|
+
this.rangeStep = this.step === undefined ? undefined : this.nonlinear ? 'any' : this.step;
|
|
5061
|
+
this.rangeValue = this.value === undefined ? undefined : this.nonlinear ? this.toRange(this.value) : this.value;
|
|
5062
|
+
}
|
|
5024
5063
|
static get styles() {
|
|
5025
|
-
return [super.styles, i$
|
|
5064
|
+
return [super.styles, i$3`
|
|
5026
5065
|
:host {
|
|
5066
|
+
---decidables-slider-background-color: var(--decidables-slider-background-color, var(---color-element-disabled));
|
|
5067
|
+
---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
|
|
5068
|
+
---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
|
|
5069
|
+
|
|
5027
5070
|
---shadow-2-rotate: var(--shadow-2-rotate, ${r$3(this.cssBoxShadow(2, true, false))});
|
|
5028
5071
|
---shadow-4-rotate: var(--shadow-4-rotate, ${r$3(this.cssBoxShadow(4, true, false))});
|
|
5029
5072
|
---shadow-8-rotate: var(--shadow-8-rotate, ${r$3(this.cssBoxShadow(8, true, false))});
|
|
@@ -5041,7 +5084,10 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5041
5084
|
}
|
|
5042
5085
|
|
|
5043
5086
|
.range {
|
|
5044
|
-
|
|
5087
|
+
position: relative;
|
|
5088
|
+
display: flex;
|
|
5089
|
+
|
|
5090
|
+
flex-direction: row;
|
|
5045
5091
|
|
|
5046
5092
|
width: 3.5rem;
|
|
5047
5093
|
height: 4.75rem;
|
|
@@ -5052,6 +5098,8 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5052
5098
|
--decidables-spinner-input-width: 3.5rem;
|
|
5053
5099
|
|
|
5054
5100
|
margin: 0 0.25rem 0.25rem;
|
|
5101
|
+
|
|
5102
|
+
background: var(---decidables-spinner-background-color);
|
|
5055
5103
|
}
|
|
5056
5104
|
|
|
5057
5105
|
/* Adapted from http://danielstern.ca/range.css/#/ */
|
|
@@ -5090,14 +5138,14 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5090
5138
|
width: 100%;
|
|
5091
5139
|
height: 4px;
|
|
5092
5140
|
|
|
5093
|
-
background: var(---
|
|
5141
|
+
background: var(---decidables-slider-background-color);
|
|
5094
5142
|
border: 0;
|
|
5095
5143
|
border-radius: 2px;
|
|
5096
5144
|
box-shadow: none;
|
|
5097
5145
|
}
|
|
5098
5146
|
|
|
5099
5147
|
input[type=range]:focus::-webkit-slider-runnable-track {
|
|
5100
|
-
background: var(---
|
|
5148
|
+
background: var(---decidables-slider-background-color);
|
|
5101
5149
|
}
|
|
5102
5150
|
|
|
5103
5151
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
@@ -5105,7 +5153,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5105
5153
|
width: 100%;
|
|
5106
5154
|
height: 4px;
|
|
5107
5155
|
|
|
5108
|
-
background: var(---
|
|
5156
|
+
background: var(---decidables-slider-background-color);
|
|
5109
5157
|
border: 0;
|
|
5110
5158
|
border-radius: 2px;
|
|
5111
5159
|
box-shadow: none;
|
|
@@ -5125,7 +5173,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5125
5173
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5126
5174
|
input[type=range]::-ms-fill-lower {
|
|
5127
5175
|
background: #cccccc;
|
|
5128
|
-
/* background: var(---
|
|
5176
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5129
5177
|
border: 0;
|
|
5130
5178
|
border-radius: 2px;
|
|
5131
5179
|
box-shadow: none;
|
|
@@ -5134,7 +5182,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5134
5182
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5135
5183
|
input[type=range]::-ms-fill-upper {
|
|
5136
5184
|
background: #cccccc;
|
|
5137
|
-
/* background: var(---
|
|
5185
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5138
5186
|
border: 0;
|
|
5139
5187
|
border-radius: 2px;
|
|
5140
5188
|
box-shadow: none;
|
|
@@ -5142,12 +5190,12 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5142
5190
|
|
|
5143
5191
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5144
5192
|
input[type=range]:focus::-ms-fill-lower {
|
|
5145
|
-
background: var(---
|
|
5193
|
+
background: var(---decidables-slider-background-color);
|
|
5146
5194
|
}
|
|
5147
5195
|
|
|
5148
5196
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5149
5197
|
input[type=range]:focus::-ms-fill-upper {
|
|
5150
|
-
background: var(---
|
|
5198
|
+
background: var(---decidables-slider-background-color);
|
|
5151
5199
|
}
|
|
5152
5200
|
|
|
5153
5201
|
/* Thumb */
|
|
@@ -5165,12 +5213,12 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5165
5213
|
}
|
|
5166
5214
|
|
|
5167
5215
|
input[type=range]:disabled::-webkit-slider-thumb {
|
|
5168
|
-
background: var(---
|
|
5216
|
+
background: var(---decidables-slider-background-color);
|
|
5169
5217
|
box-shadow: none;
|
|
5170
5218
|
}
|
|
5171
5219
|
|
|
5172
5220
|
input[type=range]:enabled::-webkit-slider-thumb {
|
|
5173
|
-
background: var(---
|
|
5221
|
+
background: var(---decidables-slider-color);
|
|
5174
5222
|
box-shadow: var(---shadow-2-rotate);
|
|
5175
5223
|
}
|
|
5176
5224
|
|
|
@@ -5201,13 +5249,13 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5201
5249
|
|
|
5202
5250
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5203
5251
|
input[type=range]:disabled::-moz-range-thumb {
|
|
5204
|
-
background: var(---
|
|
5252
|
+
background: var(---decidables-slider-background-color);
|
|
5205
5253
|
box-shadow: none;
|
|
5206
5254
|
}
|
|
5207
5255
|
|
|
5208
5256
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5209
5257
|
input[type=range]:enabled::-moz-range-thumb {
|
|
5210
|
-
background: var(---
|
|
5258
|
+
background: var(---decidables-slider-color);
|
|
5211
5259
|
box-shadow: var(---shadow-2-rotate);
|
|
5212
5260
|
}
|
|
5213
5261
|
|
|
@@ -5244,13 +5292,13 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5244
5292
|
|
|
5245
5293
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5246
5294
|
input[type=range]:disabled::-ms-thumb {
|
|
5247
|
-
background: var(---
|
|
5295
|
+
background: var(---decidables-slider-background-color);
|
|
5248
5296
|
box-shadow: none;
|
|
5249
5297
|
}
|
|
5250
5298
|
|
|
5251
5299
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5252
5300
|
input[type=range]:enabled::-ms-thumb {
|
|
5253
|
-
background: var(---
|
|
5301
|
+
background: var(---decidables-slider-color);
|
|
5254
5302
|
box-shadow: var(---shadow-2-rotate);
|
|
5255
5303
|
}
|
|
5256
5304
|
|
|
@@ -5272,6 +5320,33 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5272
5320
|
:host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {
|
|
5273
5321
|
box-shadow: var(---shadow-8-rotate);
|
|
5274
5322
|
}
|
|
5323
|
+
|
|
5324
|
+
datalist {
|
|
5325
|
+
position: absolute;
|
|
5326
|
+
left: 2rem;
|
|
5327
|
+
z-index: -1;
|
|
5328
|
+
display: flex;
|
|
5329
|
+
|
|
5330
|
+
flex-direction: column;
|
|
5331
|
+
|
|
5332
|
+
align-items: flex-start;
|
|
5333
|
+
justify-content: space-between;
|
|
5334
|
+
|
|
5335
|
+
height: 4.75rem;
|
|
5336
|
+
|
|
5337
|
+
font-size: 0.75rem;
|
|
5338
|
+
}
|
|
5339
|
+
|
|
5340
|
+
option {
|
|
5341
|
+
padding: 0;
|
|
5342
|
+
|
|
5343
|
+
line-height: 0.8;
|
|
5344
|
+
min-block-size: 0;
|
|
5345
|
+
}
|
|
5346
|
+
|
|
5347
|
+
option::before {
|
|
5348
|
+
content: "– ";
|
|
5349
|
+
}
|
|
5275
5350
|
`];
|
|
5276
5351
|
}
|
|
5277
5352
|
render() {
|
|
@@ -5280,9 +5355,15 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5280
5355
|
<slot></slot>
|
|
5281
5356
|
</label>
|
|
5282
5357
|
<div class="range">
|
|
5283
|
-
<input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.
|
|
5358
|
+
<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)}>
|
|
5359
|
+
${this.scale ? x$1`
|
|
5360
|
+
<datalist id="ticks">
|
|
5361
|
+
<option value=${o(this.rangeMax)} label=${o(this.max)}></option>
|
|
5362
|
+
<option value=${o(this.rangeMin)} label=${o(this.min)}></option>
|
|
5363
|
+
</datalist>
|
|
5364
|
+
` : x$1``}
|
|
5284
5365
|
</div>
|
|
5285
|
-
<decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.
|
|
5366
|
+
<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>
|
|
5286
5367
|
`;
|
|
5287
5368
|
}
|
|
5288
5369
|
}
|
|
@@ -5332,7 +5413,7 @@ class DecidablesSpinner extends DecidablesElement {
|
|
|
5332
5413
|
this.value = event.target.value;
|
|
5333
5414
|
}
|
|
5334
5415
|
static get styles() {
|
|
5335
|
-
return [super.styles, i$
|
|
5416
|
+
return [super.styles, i$3`
|
|
5336
5417
|
:host {
|
|
5337
5418
|
---decidables-spinner-font-size: var(--decidables-spinner-font-size, 1.125rem);
|
|
5338
5419
|
---decidables-spinner-input-width: var(--decidables-spinner-input-width, 4rem);
|
|
@@ -5471,7 +5552,7 @@ class DecidablesSwitch extends DecidablesElement {
|
|
|
5471
5552
|
}));
|
|
5472
5553
|
}
|
|
5473
5554
|
static get styles() {
|
|
5474
|
-
return [super.styles, i$
|
|
5555
|
+
return [super.styles, i$3`
|
|
5475
5556
|
:host {
|
|
5476
5557
|
display: flex;
|
|
5477
5558
|
|
|
@@ -5624,7 +5705,7 @@ class DecidablesToggle extends DecidablesElement {
|
|
|
5624
5705
|
this.disabled = false;
|
|
5625
5706
|
}
|
|
5626
5707
|
static get styles() {
|
|
5627
|
-
return [super.styles, i$
|
|
5708
|
+
return [super.styles, i$3`
|
|
5628
5709
|
fieldset {
|
|
5629
5710
|
display: flex;
|
|
5630
5711
|
|
|
@@ -5699,7 +5780,7 @@ class DecidablesToggleOption extends DecidablesElement {
|
|
|
5699
5780
|
}));
|
|
5700
5781
|
}
|
|
5701
5782
|
static get styles() {
|
|
5702
|
-
return [super.styles, i$
|
|
5783
|
+
return [super.styles, i$3`
|
|
5703
5784
|
:host {
|
|
5704
5785
|
display: flex;
|
|
5705
5786
|
}
|
|
@@ -5893,7 +5974,7 @@ class AccumulableElement extends DecidablesElement {
|
|
|
5893
5974
|
}, {});
|
|
5894
5975
|
}
|
|
5895
5976
|
static get styles() {
|
|
5896
|
-
return [super.styles, i$
|
|
5977
|
+
return [super.styles, i$3`
|
|
5897
5978
|
:host {
|
|
5898
5979
|
/* Declare base colors */
|
|
5899
5980
|
${r$3(Object.keys(AccumulableElement.colors).map(color => {
|
|
@@ -6056,7 +6137,7 @@ class AccumulableControl extends AccumulableElement {
|
|
|
6056
6137
|
this.state = 'ended';
|
|
6057
6138
|
}
|
|
6058
6139
|
static get styles() {
|
|
6059
|
-
return [super.styles, i$
|
|
6140
|
+
return [super.styles, i$3`
|
|
6060
6141
|
:host {
|
|
6061
6142
|
display: inline-block;
|
|
6062
6143
|
}
|
|
@@ -6083,15 +6164,15 @@ class AccumulableControl extends AccumulableElement {
|
|
|
6083
6164
|
render() {
|
|
6084
6165
|
return x$1`
|
|
6085
6166
|
<div class="holder">
|
|
6086
|
-
${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``}
|
|
6167
|
+
${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``}
|
|
6087
6168
|
${this.resample ? x$1`
|
|
6088
6169
|
<div class="buttons">
|
|
6089
6170
|
${this.resample ? x$1`<decidables-button name="resample" @click=${this.doResample.bind(this)}>Resample</decidables-button>` : x$1``}
|
|
6090
6171
|
</div>
|
|
6091
6172
|
` : x$1``}
|
|
6092
|
-
${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``}
|
|
6093
|
-
${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``}
|
|
6094
|
-
${this.color
|
|
6173
|
+
${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``}
|
|
6174
|
+
${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``}
|
|
6175
|
+
${this.color != null ? x$1`
|
|
6095
6176
|
<decidables-toggle class="color" @change=${this.chooseColor.bind(this)}>
|
|
6096
6177
|
<span slot="label">Emphasis</span>
|
|
6097
6178
|
<decidables-toggle-option name="toggle" value="none" ?checked=${this.color === 'none'}>None</decidables-toggle-option>
|
|
@@ -6116,13 +6197,13 @@ customElements.define('accumulable-control', AccumulableControl);
|
|
|
6116
6197
|
DDMMath Static Class - Not intended for instantiation!
|
|
6117
6198
|
|
|
6118
6199
|
Model parameters:
|
|
6119
|
-
a = boundary separation
|
|
6120
|
-
z = starting point as a proportion of a
|
|
6121
|
-
v = drift rate (per second)
|
|
6122
|
-
t0 = non-decision time (in milliseconds)
|
|
6123
|
-
s = within-trial variability in drift rate (s^2 = infinitesimal variance)
|
|
6200
|
+
a = boundary separation [0, Infinity)
|
|
6201
|
+
z = starting point as a proportion of a (0, 1)
|
|
6202
|
+
v = drift rate (per second) (-Infinity, Infinity)
|
|
6203
|
+
t0 = non-decision time (in milliseconds) (0, Infinity)
|
|
6204
|
+
s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)
|
|
6124
6205
|
|
|
6125
|
-
zPrime = starting point on a 0-to-a scale (typically used in published equations)
|
|
6206
|
+
zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)
|
|
6126
6207
|
|
|
6127
6208
|
Behavioral variables:
|
|
6128
6209
|
pE = proportion of error trials
|
|
@@ -6142,7 +6223,37 @@ customElements.define('accumulable-control', AccumulableControl);
|
|
|
6142
6223
|
EZ-diffusion model (Wagenmakers et al., 2007)
|
|
6143
6224
|
*/
|
|
6144
6225
|
class DDMMath {
|
|
6145
|
-
static s =
|
|
6226
|
+
static s = {
|
|
6227
|
+
DEFAULT: 1
|
|
6228
|
+
};
|
|
6229
|
+
static a = {
|
|
6230
|
+
DEFAULT: 1.2,
|
|
6231
|
+
MIN: 0.01,
|
|
6232
|
+
MAX: 2.0,
|
|
6233
|
+
STEP: 0.01,
|
|
6234
|
+
JUMP: 0.1
|
|
6235
|
+
};
|
|
6236
|
+
static z = {
|
|
6237
|
+
DEFAULT: 0.55,
|
|
6238
|
+
MIN: 0.01,
|
|
6239
|
+
MAX: 0.99,
|
|
6240
|
+
STEP: 0.01,
|
|
6241
|
+
JUMP: 0.1
|
|
6242
|
+
};
|
|
6243
|
+
static v = {
|
|
6244
|
+
DEFAULT: 1.5,
|
|
6245
|
+
MIN: 0.01,
|
|
6246
|
+
MAX: 5.0,
|
|
6247
|
+
STEP: 0.01,
|
|
6248
|
+
JUMP: 0.1
|
|
6249
|
+
};
|
|
6250
|
+
static t0 = {
|
|
6251
|
+
DEFAULT: 150,
|
|
6252
|
+
MIN: 0,
|
|
6253
|
+
MAX: 500,
|
|
6254
|
+
STEP: 1,
|
|
6255
|
+
JUMP: 10
|
|
6256
|
+
};
|
|
6146
6257
|
|
|
6147
6258
|
// Calculate a bunch of statistics for an array of trials
|
|
6148
6259
|
static trials2stats(trials) {
|
|
@@ -6210,7 +6321,7 @@ class DDMMath {
|
|
|
6210
6321
|
}
|
|
6211
6322
|
|
|
6212
6323
|
// Probability of an Error Response
|
|
6213
|
-
static azv2pE(a, z, v, s = DDMMath.s) {
|
|
6324
|
+
static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6214
6325
|
const zPrime = a * z;
|
|
6215
6326
|
const A = Math.exp(-2 * v * a / s ** 2);
|
|
6216
6327
|
const Z = Math.exp(-2 * v * zPrime / s ** 2);
|
|
@@ -6218,13 +6329,13 @@ class DDMMath {
|
|
|
6218
6329
|
}
|
|
6219
6330
|
|
|
6220
6331
|
// Probability of a Correct Response
|
|
6221
|
-
static azv2pC(a, z, v, s = DDMMath.s) {
|
|
6332
|
+
static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6222
6333
|
return DDMMath.azv2pE(a, 1 - z, -v, s);
|
|
6223
6334
|
}
|
|
6224
6335
|
|
|
6225
6336
|
// Mean Overall RT
|
|
6226
6337
|
// Equation 5 (Grasman et al., 2009)
|
|
6227
|
-
static azvt02m(a, z, v, t0, s = DDMMath.s) {
|
|
6338
|
+
static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6228
6339
|
const zPrime = a * z;
|
|
6229
6340
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6230
6341
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6234,7 +6345,7 @@ class DDMMath {
|
|
|
6234
6345
|
|
|
6235
6346
|
// SD Overall RT
|
|
6236
6347
|
// Equation 6 (Grasman et al., 2009)
|
|
6237
|
-
static azv2sd(a, z, v, s = DDMMath.s) {
|
|
6348
|
+
static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6238
6349
|
const zPrime = a * z;
|
|
6239
6350
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6240
6351
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6244,7 +6355,7 @@ class DDMMath {
|
|
|
6244
6355
|
|
|
6245
6356
|
// Mean Error RT
|
|
6246
6357
|
// Equation 13 (Grasman et al., 2009)
|
|
6247
|
-
static azvt02mE(a, z, v, t0, s = DDMMath.s) {
|
|
6358
|
+
static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6248
6359
|
function phi(x, y) {
|
|
6249
6360
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6250
6361
|
}
|
|
@@ -6255,7 +6366,7 @@ class DDMMath {
|
|
|
6255
6366
|
|
|
6256
6367
|
// SD Error RT
|
|
6257
6368
|
// Equation 14 (Grasman et al., 2009)
|
|
6258
|
-
static azv2sdE(a, z, v, s = DDMMath.s) {
|
|
6369
|
+
static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6259
6370
|
function phi(x, y) {
|
|
6260
6371
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6261
6372
|
}
|
|
@@ -6265,17 +6376,17 @@ class DDMMath {
|
|
|
6265
6376
|
}
|
|
6266
6377
|
|
|
6267
6378
|
// Mean Correct RT
|
|
6268
|
-
static azvt02mC(a, z, v, t0, s = DDMMath.s) {
|
|
6379
|
+
static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6269
6380
|
return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
|
|
6270
6381
|
}
|
|
6271
6382
|
|
|
6272
6383
|
// SD Correct RT
|
|
6273
|
-
static azv2sdC(a, z, v, s = DDMMath.s) {
|
|
6384
|
+
static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6274
6385
|
return DDMMath.azv2sdE(a, 1 - z, -v, s);
|
|
6275
6386
|
}
|
|
6276
6387
|
|
|
6277
6388
|
// Density of Error RT
|
|
6278
|
-
static tazv2gE(t, a, z, v, s = DDMMath.s) {
|
|
6389
|
+
static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6279
6390
|
if (!t) return 0;
|
|
6280
6391
|
const zPrime = a * z;
|
|
6281
6392
|
const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
|
|
@@ -6292,7 +6403,7 @@ class DDMMath {
|
|
|
6292
6403
|
}
|
|
6293
6404
|
|
|
6294
6405
|
// Density of Correct RT
|
|
6295
|
-
static tazv2gC(t, a, z, v, s = DDMMath.s) {
|
|
6406
|
+
static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6296
6407
|
return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
|
|
6297
6408
|
}
|
|
6298
6409
|
|
|
@@ -6427,10 +6538,7 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6427
6538
|
this.startTime = undefined; // Start time of current trial
|
|
6428
6539
|
this.rt = undefined; // RT for current trial
|
|
6429
6540
|
|
|
6430
|
-
this.
|
|
6431
|
-
this.errorCount = 0; // Count of Error Trials
|
|
6432
|
-
this.nrCount = 0; // Count of No Response trials
|
|
6433
|
-
|
|
6541
|
+
this.data = {};
|
|
6434
6542
|
this.trials = []; // Record of trials in block
|
|
6435
6543
|
this.alignState();
|
|
6436
6544
|
}
|
|
@@ -6447,11 +6555,10 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6447
6555
|
}
|
|
6448
6556
|
}
|
|
6449
6557
|
get totalPayoff() {
|
|
6450
|
-
return this.correctCount * this.correctPayoff + this.errorCount * this.errorPayoff + this.nrCount * this.nrPayoff;
|
|
6558
|
+
return this.data.correctCount * this.correctPayoff + this.data.errorCount * this.errorPayoff + this.data.nrCount * this.nrPayoff;
|
|
6451
6559
|
}
|
|
6452
6560
|
alignState() {
|
|
6453
|
-
|
|
6454
|
-
Object.assign(this, stats);
|
|
6561
|
+
this.data = DDMMath.trials2stats(this.trials);
|
|
6455
6562
|
}
|
|
6456
6563
|
start(signal, trial) {
|
|
6457
6564
|
this.startTime = Date.now();
|
|
@@ -6466,7 +6573,6 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6466
6573
|
this.state = 'feedback';
|
|
6467
6574
|
if (this.response === undefined) {
|
|
6468
6575
|
this.outcome = 'nr';
|
|
6469
|
-
this.nrCount += 1;
|
|
6470
6576
|
this.rt = undefined;
|
|
6471
6577
|
this.trials.push({
|
|
6472
6578
|
trial: this.trialCount,
|
|
@@ -6491,10 +6597,8 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6491
6597
|
this.response = response;
|
|
6492
6598
|
if (this.signal === this.response) {
|
|
6493
6599
|
this.outcome = 'correct';
|
|
6494
|
-
this.correctCount += 1;
|
|
6495
6600
|
} else if (this.signal !== this.response) {
|
|
6496
6601
|
this.outcome = 'error';
|
|
6497
|
-
this.errorCount += 1;
|
|
6498
6602
|
}
|
|
6499
6603
|
this.trials.push({
|
|
6500
6604
|
trial: this.trialCount,
|
|
@@ -6513,16 +6617,7 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6513
6617
|
response: this.response,
|
|
6514
6618
|
outcome: this.outcome,
|
|
6515
6619
|
payoff: this.trialPayoff,
|
|
6516
|
-
|
|
6517
|
-
errorCount: this.errorCount,
|
|
6518
|
-
nrCount: this.nrCount,
|
|
6519
|
-
accuracy: this.accuracy,
|
|
6520
|
-
meanRT: this.meanRT,
|
|
6521
|
-
correctMeanRT: this.correctMeanRT,
|
|
6522
|
-
errorMeanRT: this.errorMeanRT,
|
|
6523
|
-
sdRT: this.sdRT,
|
|
6524
|
-
correctSDRT: this.correctSDRT,
|
|
6525
|
-
errorSDRT: this.errorSDRT,
|
|
6620
|
+
data: this.data,
|
|
6526
6621
|
totalPayoff: this.totalPayoff
|
|
6527
6622
|
},
|
|
6528
6623
|
bubbles: true
|
|
@@ -6535,9 +6630,6 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6535
6630
|
this.signal = undefined;
|
|
6536
6631
|
this.response = undefined;
|
|
6537
6632
|
this.outcome = undefined;
|
|
6538
|
-
this.correctCount = 0;
|
|
6539
|
-
this.errorCount = 0;
|
|
6540
|
-
this.nrCount = 0;
|
|
6541
6633
|
this.trials = [];
|
|
6542
6634
|
this.alignState();
|
|
6543
6635
|
}
|
|
@@ -6561,7 +6653,7 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6561
6653
|
super.disconnectedCallback();
|
|
6562
6654
|
}
|
|
6563
6655
|
static get styles() {
|
|
6564
|
-
return [super.styles, i$
|
|
6656
|
+
return [super.styles, i$3`
|
|
6565
6657
|
:host {
|
|
6566
6658
|
display: inline-block;
|
|
6567
6659
|
}
|
|
@@ -6891,7 +6983,7 @@ class AccumulableTable extends AccumulableElement {
|
|
|
6891
6983
|
this.sendEvent();
|
|
6892
6984
|
}
|
|
6893
6985
|
static get styles() {
|
|
6894
|
-
return [super.styles, i$
|
|
6986
|
+
return [super.styles, i$3`
|
|
6895
6987
|
:host {
|
|
6896
6988
|
display: inline-block;
|
|
6897
6989
|
}
|
|
@@ -7228,7 +7320,7 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
|
|
|
7228
7320
|
};
|
|
7229
7321
|
}
|
|
7230
7322
|
|
|
7231
|
-
var WorkerFactory = 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;AACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;AACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACe,MAAMA,OAAO,CAAC;IAC3B,OAAOC,CAAC,GAAG,CAAC,CAAA;;EAEZ;IACA,OAAOC,YAAYA,CAACC,MAAM,EAAE;MAC1B,MAAMC,KAAK,GAAG,EAAE,CAAA;;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,CAAA;EAC7BH,UAAAA,WAAW,CAACI,YAAY,IAAIH,KAAK,CAACI,EAAE,CAAA;EACpC,UAAA,MAAA;EACF,QAAA,KAAK,OAAO;YACVL,WAAW,CAACM,UAAU,IAAI,CAAC,CAAA;EAC3BN,UAAAA,WAAW,CAACO,UAAU,IAAIN,KAAK,CAACI,EAAE,CAAA;EAClC,UAAA,MAAA;EACF,QAAA,KAAK,IAAI;YACPL,WAAW,CAACQ,OAAO,IAAI,CAAC,CAAA;EACxB,UAAA,MAAA;EAEA;EACJ,OAAA;EACA,MAAA,OAAOR,WAAW,CAAA;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,CAAA;EACd,KACF,CAAC,CAAA;;EAED;EACAV,IAAAA,KAAK,CAACM,YAAY,GAAGL,IAAI,CAACK,YAAY,CAAA;EACtCN,IAAAA,KAAK,CAACS,UAAU,GAAGR,IAAI,CAACQ,UAAU,CAAA;EAClCT,IAAAA,KAAK,CAACW,OAAO,GAAGV,IAAI,CAACU,OAAO,CAAA;EAC5BX,IAAAA,KAAK,CAACY,QAAQ,GAAGX,IAAI,CAACK,YAAY,IAAIL,IAAI,CAACK,YAAY,GAAGL,IAAI,CAACQ,UAAU,GAAGR,IAAI,CAACU,OAAO,CAAC,CAAA;MAEzFX,KAAK,CAACa,aAAa,GAAGZ,IAAI,CAACM,YAAY,GAAGN,IAAI,CAACK,YAAY,CAAA;MAC3DN,KAAK,CAACc,WAAW,GAAGb,IAAI,CAACS,UAAU,GAAGT,IAAI,CAACQ,UAAU,CAAA;EACrDT,IAAAA,KAAK,CAACe,MAAM,GAAG,CAACd,IAAI,CAACM,YAAY,GAAGN,IAAI,CAACS,UAAU,KAAKT,IAAI,CAACK,YAAY,GAAGL,IAAI,CAACQ,UAAU,CAAC,CAAA;;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,CAAA;EAChDZ,UAAAA,WAAW,CAACe,SAAS,IAAI,CAACd,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACa,aAAa,KAAK,CAAC,CAAA;EAC9D,UAAA,MAAA;EACF,QAAA,KAAK,OAAO;EACVV,UAAAA,WAAW,CAACc,EAAE,IAAI,CAACb,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACe,MAAM,KAAK,CAAC,CAAA;EAChDZ,UAAAA,WAAW,CAACgB,OAAO,IAAI,CAACf,KAAK,CAACI,EAAE,GAAGR,KAAK,CAACc,WAAW,KAAK,CAAC,CAAA;EAC1D,UAAA,MAAA;EAEA;EACJ,OAAA;EACA,MAAA,OAAOX,WAAW,CAAA;EACpB,KAAC,EACD;EACEc,MAAAA,EAAE,EAAE,CAAC;EACLC,MAAAA,SAAS,EAAE,CAAC;EACZC,MAAAA,OAAO,EAAE,CAAA;EACX,KACF,CAAC,CAAA;;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,CAAA;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,CAAA;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,CAAA;EAEP,IAAA,OAAOvB,KAAK,CAAA;EACd,GAAA;;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,CAAA;EAEpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,CAAA;EACzC,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC,CAAA;MAE9C,OAAO,CAACkC,CAAC,GAAGE,CAAC,KAAKF,CAAC,GAAG,CAAC,CAAC,CAAA;EAC1B,GAAA;;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,CAAA;EACxC,GAAA;;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,CAAA;EACpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;EAC7C,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;EAElD,IAAA,MAAMwC,IAAI,GAAG,EAAEP,MAAM,GAAGD,CAAC,CAAC,GAAIF,CAAC,GAAGE,CAAC,IAAKI,CAAC,GAAGF,CAAC,CAAC,CAAA;EAC9C,IAAA,OAAOK,EAAE,GAAGC,IAAI,GAAG,IAAI,CAAA;EACzB,GAAA;;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,CAAA;EACpB,IAAA,MAAMG,CAAC,GAAGV,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGF,CAAC,GAAI9B,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;EAC7C,IAAA,MAAMoC,CAAC,GAAGZ,IAAI,CAACW,GAAG,CAAE,CAAC,CAAC,GAAGH,CAAC,GAAGC,MAAM,GAAIjC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;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,CAAC,CAAC,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,CAAA;EAEV,IAAA,OAAOR,IAAI,CAACC,IAAI,CAACiB,QAAQ,CAAC,GAAG,IAAI,CAAA;EACnC,GAAA;;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,CAAA;EAC5E,KAAA;EACA,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC,CAAA;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,CAAA;EACrC,IAAA,OAAOS,EAAE,GAAGC,IAAI,GAAG,IAAI,CAAA;EACzB,GAAA;;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,CAAA;EAC5E,KAAA;EACA,IAAA,MAAMiC,MAAM,GAAGH,CAAC,GAAGC,CAAC,CAAA;EAEpB,IAAA,MAAMW,QAAQ,GAEV,CAAC,CAAC,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,CAAA;EAED,IAAA,OAAON,IAAI,CAACC,IAAI,CAACiB,QAAQ,CAAC,GAAG,IAAI,CAAA;EACnC,GAAA;;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,CAAA;EAC9C,GAAA;;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,CAAA;EACzC,GAAA;;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,CAAA;EAEhB,IAAA,MAAMlB,MAAM,GAAGH,CAAC,GAAGC,CAAC,CAAA;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,CAAA;MAE7E,IAAIsD,CAAC,GAAG,CAAC,CAAA;MACT,IAAIC,IAAI,GAAG,CAAC,CAAA;MACZ,IAAIC,GAAG,GAAG,CAAC,CAAA;MACX,GAAG;EACDF,MAAAA,CAAC,IAAI,CAAC,CAAA;QAENC,IAAI,GAAGD,CAAC,GACJ9B,IAAI,CAACiC,GAAG,CAAEjC,IAAI,CAAC6B,EAAE,GAAGpB,MAAM,GAAGqB,CAAC,GAAIxB,CAAC,CAAC,GACpCN,IAAI,CAACW,GAAG,CAAC,CAAC,GAAG,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,CAAA;EAE1FK,MAAAA,GAAG,IAAID,IAAI,CAAA;EACb,KAAC,QAAQD,CAAC,GAAG,GAAG,EAAE;;MAElB,OAAOF,IAAI,GAAGI,GAAG,CAAA;EACnB,GAAA;;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,CAAA;EAC5C,GAAA;;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,CAAAA;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,CAAC,CAAE,CAAA;EAC5C,KAAA;MAEA,SAASC,KAAKA,CAACC,CAAC,EAAE;QAChB,OAAO1C,IAAI,CAAC2C,GAAG,CAACD,CAAC,IAAI,CAAC,GAAGA,CAAC,CAAC,CAAC,CAAA;EAC9B,KAAA;EAEA,IAAA,MAAME,GAAG,GAAG,CAACP,EAAE,GAAG,IAAI,KAAK,CAAC,CAAA;EAC5B,IAAA,MAAMQ,GAAG,GAAGP,CAAC,GAAG,IAAI,CAAA;EAEpB,IAAA,MAAMQ,EAAE,GAAGtE,CAAC,IAAI,CAAC,CAAA;EACjB,IAAA,MAAMuE,CAAC,GAAGN,KAAK,CAACL,EAAE,CAAC,CAAA;EACnB,IAAA,MAAMf,CAAC,GAAI0B,CAAC,IAAIA,CAAC,GAAGX,EAAE,IAAI,CAAC,GAAGW,CAAC,GAAGX,EAAE,GAAGA,EAAE,GAAG,GAAG,CAAC,GAAIQ,GAAG,CAAA;EACvD,IAAA,MAAMpC,CAAC,GAAG+B,IAAI,CAACH,EAAE,GAAG,GAAG,CAAC,GAAG5D,CAAC,GAAG6C,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAA;MAC3C,MAAMf,CAAC,GAAIwC,EAAE,GAAGL,KAAK,CAACL,EAAE,CAAC,GAAI5B,CAAC,CAAA;EAC9B,IAAA,MAAMc,CAAC,GAAI,CAACd,CAAC,GAAGF,CAAC,GAAIwC,EAAE,CAAA;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,CAAA;MACnE,MAAMP,EAAE,GAAI8B,GAAG,GAAGA,GAAG,GAAGG,GAAG,GAAG,IAAK,CAAC;;EAEpC,IAAA,MAAMC,OAAO,GAAGlC,EAAE,GAAG,IAAI,CAAA;MACzB,OAAO;QACLP,CAAC;QACDF,CAAC;EACDS,MAAAA,EAAE,EAAEkC,OAAO;EACXzE,MAAAA,CAAAA;OACD,CAAA;EACH,GAAA;IAEA,OAAO0E,QAAQA,GAAG;EAChB,IAAA,MAAM,IAAIC,KAAK,CAAC,8BAA8B,CAAC,CAAA;EACjD,GAAA;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,CAAAA;EAAC,GAAC,CAAC,CAAA;;EAE7D;EACA,EAAA,MAAM8B,CAAC,GAAG,CAACmD,KAAK,CAACF,MAAM,CAACjD,CAAC,CAAC,GAAGiD,MAAM,CAACjD,CAAC,GAAG,GAAG,CAAA;EAC3C,EAAA,MAAMC,CAAC,GAAG,CAACkD,KAAK,CAACF,MAAM,CAAChD,CAAC,CAAC,GAAGgD,MAAM,CAAChD,CAAC,GAAG,GAAG,CAAA;EAC3C,EAAA,MAAMC,CAAC,GAAG,CAACiD,KAAK,CAACF,MAAM,CAAC/C,CAAC,CAAC,GAAG+C,MAAM,CAAC/C,CAAC,GAAG,GAAG,CAAA;EAC3C,EAAA,MAAMO,EAAE,GAAG,CAAC0C,KAAK,CAACF,MAAM,CAACxC,EAAE,CAAC,GAAGwC,MAAM,CAACxC,EAAE,GAAG,GAAG,CAAA;EAC9C,EAAA,MAAMvC,CAAC,GAAG,CAACiF,KAAK,CAACF,MAAM,CAAC/E,CAAC,CAAC,GAAG+E,MAAM,CAAC/E,CAAC,GAAGD,OAAO,CAACC,CAAC,CAAA;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,CAAA;KAC7B,CAAA;IAED4C,IAAI,CAACO,WAAW,CAAC;EACfJ,IAAAA,MAAM,EAAE;QACNjD,CAAC;QAAEC,CAAC;QAAEC,CAAC;QAAEO,EAAE;EAAEvC,MAAAA,CAAAA;OACd;EACDkF,IAAAA,SAAAA;EACF,GAAC,CAAC,CAAA;EACJ,CAAC;;;;;;"}');
|
|
7323
|
+
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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"}');
|
|
7232
7324
|
/* eslint-enable */
|
|
7233
7325
|
|
|
7234
7326
|
/*
|
|
@@ -7244,10 +7336,10 @@ class DDMFit extends AccumulableElement {
|
|
|
7244
7336
|
}
|
|
7245
7337
|
constructor() {
|
|
7246
7338
|
super();
|
|
7247
|
-
this.a =
|
|
7248
|
-
this.z =
|
|
7249
|
-
this.v =
|
|
7250
|
-
this.t0 =
|
|
7339
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7340
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7341
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7342
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7251
7343
|
this.observed = {};
|
|
7252
7344
|
this.predicted = {};
|
|
7253
7345
|
this.working = false;
|
|
@@ -7295,7 +7387,7 @@ class DDMFit extends AccumulableElement {
|
|
|
7295
7387
|
this.fit();
|
|
7296
7388
|
}
|
|
7297
7389
|
static get styles() {
|
|
7298
|
-
return [super.styles, i$
|
|
7390
|
+
return [super.styles, i$3`
|
|
7299
7391
|
:host {
|
|
7300
7392
|
display: inline-block;
|
|
7301
7393
|
}
|
|
@@ -7412,7 +7504,7 @@ class DDMParameters extends AccumulableElement {
|
|
|
7412
7504
|
}));
|
|
7413
7505
|
}
|
|
7414
7506
|
static get styles() {
|
|
7415
|
-
return [super.styles, i$
|
|
7507
|
+
return [super.styles, i$3`
|
|
7416
7508
|
:host {
|
|
7417
7509
|
display: inline-block;
|
|
7418
7510
|
}
|
|
@@ -7434,15 +7526,71 @@ class DDMParameters extends AccumulableElement {
|
|
|
7434
7526
|
decidables-slider div {
|
|
7435
7527
|
margin-bottom: 0.25rem;
|
|
7436
7528
|
}
|
|
7529
|
+
|
|
7530
|
+
.a {
|
|
7531
|
+
--decidables-slider-background-color: var(---color-a-light);
|
|
7532
|
+
--decidables-slider-color: var(---color-a);
|
|
7533
|
+
}
|
|
7534
|
+
|
|
7535
|
+
.z {
|
|
7536
|
+
--decidables-slider-background-color: var(---color-z-light);
|
|
7537
|
+
--decidables-slider-color: var(---color-z);
|
|
7538
|
+
}
|
|
7539
|
+
|
|
7540
|
+
.v {
|
|
7541
|
+
--decidables-slider-background-color: var(---color-v-light);
|
|
7542
|
+
--decidables-slider-color: var(---color-v);
|
|
7543
|
+
}
|
|
7544
|
+
|
|
7545
|
+
.t0 {
|
|
7546
|
+
--decidables-slider-background-color: var(---color-t0-light);
|
|
7547
|
+
--decidables-slider-color: var(---color-t0);
|
|
7548
|
+
}
|
|
7437
7549
|
`];
|
|
7438
7550
|
}
|
|
7439
7551
|
render() {
|
|
7440
7552
|
return x$1`
|
|
7441
7553
|
<div class="holder">
|
|
7442
|
-
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7443
|
-
|
|
7444
|
-
|
|
7445
|
-
|
|
7554
|
+
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7555
|
+
?disabled=${!this.interactive}
|
|
7556
|
+
scale
|
|
7557
|
+
min=${DDMMath.a.MIN}
|
|
7558
|
+
max=${DDMMath.a.MAX}
|
|
7559
|
+
step=${DDMMath.a.STEP}
|
|
7560
|
+
.value=${+this.a.toFixed(2)}
|
|
7561
|
+
@change=${this.setBoundarySeparation.bind(this)}
|
|
7562
|
+
@input=${this.setBoundarySeparation.bind(this)}
|
|
7563
|
+
><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
|
|
7564
|
+
${this.z != null ? x$1`<decidables-slider class="z"
|
|
7565
|
+
?disabled=${!this.interactive}
|
|
7566
|
+
scale
|
|
7567
|
+
min=${DDMMath.z.MIN}
|
|
7568
|
+
max=${DDMMath.z.MAX}
|
|
7569
|
+
step=${DDMMath.z.STEP}
|
|
7570
|
+
.value=${+this.z.toFixed(2)}
|
|
7571
|
+
@change=${this.setStartingPoint.bind(this)}
|
|
7572
|
+
@input=${this.setStartingPoint.bind(this)}
|
|
7573
|
+
><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
|
|
7574
|
+
${this.v != null ? x$1`<decidables-slider class="v"
|
|
7575
|
+
?disabled=${!this.interactive}
|
|
7576
|
+
scale
|
|
7577
|
+
min=${DDMMath.v.MIN}
|
|
7578
|
+
max=${DDMMath.v.MAX}
|
|
7579
|
+
step=${DDMMath.v.STEP}
|
|
7580
|
+
.value=${+this.v.toFixed(2)}
|
|
7581
|
+
@change=${this.setDriftRate.bind(this)}
|
|
7582
|
+
@input=${this.setDriftRate.bind(this)}
|
|
7583
|
+
><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
|
|
7584
|
+
${this.t0 != null ? x$1`<decidables-slider class="t0"
|
|
7585
|
+
?disabled=${!this.interactive}
|
|
7586
|
+
scale
|
|
7587
|
+
min=${DDMMath.t0.MIN}
|
|
7588
|
+
max=${DDMMath.t0.MAX}
|
|
7589
|
+
step=${DDMMath.t0.STEP}
|
|
7590
|
+
.value=${+this.t0.toFixed(0)}
|
|
7591
|
+
@change=${this.setNondecisionTime.bind(this)}
|
|
7592
|
+
@input=${this.setNondecisionTime.bind(this)}
|
|
7593
|
+
><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
|
|
7446
7594
|
</div>`;
|
|
7447
7595
|
}
|
|
7448
7596
|
}
|
|
@@ -7580,10 +7728,10 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7580
7728
|
this.resample();
|
|
7581
7729
|
this.human = false;
|
|
7582
7730
|
this.trials = 10;
|
|
7583
|
-
this.a =
|
|
7584
|
-
this.z =
|
|
7585
|
-
this.v =
|
|
7586
|
-
this.t0 =
|
|
7731
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7732
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7733
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7734
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7587
7735
|
|
|
7588
7736
|
// this.s = null;
|
|
7589
7737
|
// this.sz = null;
|
|
@@ -7644,7 +7792,7 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7644
7792
|
while (path.at(-1).e > bounds.lower && path.at(-1).e < bounds.upper) {
|
|
7645
7793
|
path.push({
|
|
7646
7794
|
t: path.at(-1).t + this.precision * 1000,
|
|
7647
|
-
e: path.at(-1).e + drift + DDMMath.s * random()
|
|
7795
|
+
e: path.at(-1).e + drift + DDMMath.s.DEFAULT * random()
|
|
7648
7796
|
});
|
|
7649
7797
|
}
|
|
7650
7798
|
return path;
|
|
@@ -7748,7 +7896,7 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7748
7896
|
}));
|
|
7749
7897
|
}
|
|
7750
7898
|
static get styles() {
|
|
7751
|
-
return [super.styles, i$
|
|
7899
|
+
return [super.styles, i$3`
|
|
7752
7900
|
:host {
|
|
7753
7901
|
display: inline-block;
|
|
7754
7902
|
|
|
@@ -7934,10 +8082,25 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7934
8082
|
|
|
7935
8083
|
.t0z .point {
|
|
7936
8084
|
fill: var(---color-element-emphasis);
|
|
8085
|
+
stroke-width: 0;
|
|
7937
8086
|
|
|
7938
8087
|
r: 6px;
|
|
7939
8088
|
}
|
|
7940
8089
|
|
|
8090
|
+
/* Make larger targets for touch users */
|
|
8091
|
+
.interactive .touch {
|
|
8092
|
+
stroke: #000000;
|
|
8093
|
+
stroke-dasharray: none;
|
|
8094
|
+
stroke-opacity: 0;
|
|
8095
|
+
}
|
|
8096
|
+
|
|
8097
|
+
@media (pointer: coarse) {
|
|
8098
|
+
.interactive .touch {
|
|
8099
|
+
stroke-linecap: round;
|
|
8100
|
+
stroke-width: 12;
|
|
8101
|
+
}
|
|
8102
|
+
}
|
|
8103
|
+
|
|
7941
8104
|
.measure {
|
|
7942
8105
|
stroke-width: 2;
|
|
7943
8106
|
}
|
|
@@ -8112,9 +8275,9 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8112
8275
|
let t0 = timeScale.invert(event.x);
|
|
8113
8276
|
let z = (evidenceScale.invert(event.y) + this.a / 2) / this.a;
|
|
8114
8277
|
// Clamp t0
|
|
8115
|
-
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 <
|
|
8278
|
+
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8116
8279
|
// Clamp z
|
|
8117
|
-
z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z <
|
|
8280
|
+
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;
|
|
8118
8281
|
this.t0 = t0;
|
|
8119
8282
|
this.z = z;
|
|
8120
8283
|
this.alignState();
|
|
@@ -8144,7 +8307,7 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8144
8307
|
this.drag = true;
|
|
8145
8308
|
let v = (evidenceScale.invert(event.y) - this.startingPoint) / (timeScale.invert(event.x) - this.t0) * 1000;
|
|
8146
8309
|
// Clamp drift rate
|
|
8147
|
-
v = v <
|
|
8310
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8148
8311
|
this.v = v;
|
|
8149
8312
|
this.alignState();
|
|
8150
8313
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8168,12 +8331,13 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8168
8331
|
}).on('start', event => {
|
|
8169
8332
|
const element = event.currentTarget;
|
|
8170
8333
|
select(element).classed('dragging', true);
|
|
8171
|
-
}).on('drag',
|
|
8334
|
+
}).on('drag', event => {
|
|
8172
8335
|
this.drag = true;
|
|
8173
|
-
|
|
8174
|
-
|
|
8175
|
-
|
|
8176
|
-
|
|
8336
|
+
const boundary = evidenceScale.invert(event.y);
|
|
8337
|
+
let a = Math.abs(boundary * 2);
|
|
8338
|
+
// Clamp a
|
|
8339
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8340
|
+
this.a = a;
|
|
8177
8341
|
this.alignState();
|
|
8178
8342
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
8179
8343
|
detail: {
|
|
@@ -8364,8 +8528,8 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8364
8528
|
});
|
|
8365
8529
|
accuracyUnderlayerEnter.append('g').classed('axis accuracy', true);
|
|
8366
8530
|
// MERGE
|
|
8367
|
-
const evidenceScaleMerge = evidenceUnderlayerMerge.select('.axis.evidence').attr('transform', `translate(${-0.25 * this.rem}, 0)`);
|
|
8368
|
-
const densityScaleMerge = densityUnderlayerMerge.select('.axis.density').attr('transform', `translate(${-0.25 * this.rem}, 0)`);
|
|
8531
|
+
const evidenceScaleMerge = evidenceUnderlayerMerge.select('.axis.evidence').attr('transform', `translate(${ -0.25 * this.rem}, 0)`);
|
|
8532
|
+
const densityScaleMerge = densityUnderlayerMerge.select('.axis.density').attr('transform', `translate(${ -0.25 * this.rem}, 0)`);
|
|
8369
8533
|
const accuracyScaleMerge = accuracyUnderlayerMerge.select('.axis.accuracy').attr('transform', `translate(${accuracyWidth + 0.25 * this.rem}, 0)`);
|
|
8370
8534
|
const evidenceScaleTransition = evidenceScaleMerge.transition().duration(transitionDuration).ease(cubicOut).call(axisLeft(evidenceScale)).attr('font-size', null).attr('font-family', null);
|
|
8371
8535
|
const densityScaleTransition = densityScaleMerge.transition().duration(transitionDuration).ease(cubicOut).each((datum, index, elements) => {
|
|
@@ -8387,8 +8551,8 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8387
8551
|
densityTitleEnter.append('tspan').classed('name', true).text('Density');
|
|
8388
8552
|
accuracyTitleEnter.append('tspan').classed('name', true).text('Accuracy');
|
|
8389
8553
|
// MERGE
|
|
8390
|
-
evidenceUnderlayerMerge.select('.title.evidence').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${-2.5 * this.rem}, ${evidenceHeight / 2})rotate(-90)`);
|
|
8391
|
-
densityUnderlayerMerge.select('.title.density').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${-2.5 * this.rem}, ${densityHeight / 2})rotate(-90)`);
|
|
8554
|
+
evidenceUnderlayerMerge.select('.title.evidence').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${ -2.5 * this.rem}, ${evidenceHeight / 2})rotate(-90)`);
|
|
8555
|
+
densityUnderlayerMerge.select('.title.density').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${ -2.5 * this.rem}, ${densityHeight / 2})rotate(-90)`);
|
|
8392
8556
|
accuracyUnderlayerMerge.select('.title.accuracy').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${accuracyWidth + 2.25 * this.rem}, ${height / 2})rotate(90)`);
|
|
8393
8557
|
|
|
8394
8558
|
//
|
|
@@ -8614,20 +8778,23 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8614
8778
|
return `boundary ${index === 0 ? 'correct' : 'error'}`;
|
|
8615
8779
|
});
|
|
8616
8780
|
boundaryEnter.append('line').classed('line', true);
|
|
8781
|
+
boundaryEnter.append('line').classed('line touch', true);
|
|
8617
8782
|
// MERGE
|
|
8618
8783
|
const boundaryMerge = boundaryEnter.merge(boundaryUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? (event, datum) => {
|
|
8619
8784
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8620
|
-
let
|
|
8785
|
+
let {
|
|
8786
|
+
a
|
|
8787
|
+
} = this;
|
|
8621
8788
|
switch (event.key) {
|
|
8622
8789
|
case 'ArrowUp':
|
|
8623
|
-
a += datum.bound === 'upper' ? event.shiftKey ?
|
|
8790
|
+
a += datum.bound === 'upper' ? event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP : event.shiftKey ? -0.01 : -0.1;
|
|
8624
8791
|
break;
|
|
8625
8792
|
case 'ArrowDown':
|
|
8626
|
-
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ?
|
|
8793
|
+
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP;
|
|
8627
8794
|
break;
|
|
8628
8795
|
}
|
|
8629
|
-
// Clamp
|
|
8630
|
-
a = a <
|
|
8796
|
+
// Clamp a
|
|
8797
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8631
8798
|
this.a = a;
|
|
8632
8799
|
this.alignState();
|
|
8633
8800
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
@@ -8651,6 +8818,11 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8651
8818
|
}).attr('y2', datum => {
|
|
8652
8819
|
return evidenceScale(datum.value);
|
|
8653
8820
|
});
|
|
8821
|
+
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 => {
|
|
8822
|
+
return evidenceScale(datum.value);
|
|
8823
|
+
}).attr('y2', datum => {
|
|
8824
|
+
return evidenceScale(datum.value);
|
|
8825
|
+
});
|
|
8654
8826
|
// EXIT
|
|
8655
8827
|
boundaryUpdate.exit().remove();
|
|
8656
8828
|
|
|
@@ -8664,21 +8836,25 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8664
8836
|
// ENTER
|
|
8665
8837
|
const driftEnter = driftUpdate.enter().append('g').classed('drift', true);
|
|
8666
8838
|
driftEnter.append('line').classed('line', true);
|
|
8839
|
+
driftEnter.append('line').classed('line touch', true);
|
|
8667
8840
|
driftEnter.append('path').classed('arrow', true);
|
|
8841
|
+
driftEnter.append('path').classed('arrow touch', true);
|
|
8668
8842
|
// MERGE
|
|
8669
8843
|
const driftMerge = driftEnter.merge(driftUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8670
8844
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8671
|
-
let
|
|
8845
|
+
let {
|
|
8846
|
+
v
|
|
8847
|
+
} = this;
|
|
8672
8848
|
switch (event.key) {
|
|
8673
8849
|
case 'ArrowUp':
|
|
8674
|
-
v += event.shiftKey ?
|
|
8850
|
+
v += event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8675
8851
|
break;
|
|
8676
8852
|
case 'ArrowDown':
|
|
8677
|
-
v -= event.shiftKey ?
|
|
8853
|
+
v -= event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8678
8854
|
break;
|
|
8679
8855
|
}
|
|
8680
8856
|
// Clamp z
|
|
8681
|
-
v = v <
|
|
8857
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8682
8858
|
this.v = v;
|
|
8683
8859
|
this.alignState();
|
|
8684
8860
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8703,11 +8879,17 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8703
8879
|
rotate(${-Math.atan(datum.v / 1000 * scaleRatio) * (180 / Math.PI)})`;
|
|
8704
8880
|
});
|
|
8705
8881
|
driftMerge.select('.line').attr('x2', timeScale(200));
|
|
8882
|
+
driftMerge.select('.line.touch').attr('x2', timeScale(200));
|
|
8706
8883
|
driftMerge.select('.arrow').attr('d', `
|
|
8707
8884
|
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8708
8885
|
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8709
8886
|
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8710
8887
|
`);
|
|
8888
|
+
driftMerge.select('.arrow.touch').attr('d', `
|
|
8889
|
+
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8890
|
+
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8891
|
+
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8892
|
+
`);
|
|
8711
8893
|
// EXIT
|
|
8712
8894
|
driftUpdate.exit().remove();
|
|
8713
8895
|
|
|
@@ -8720,21 +8902,24 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8720
8902
|
// ENTER
|
|
8721
8903
|
const t0zEnter = t0zUpdate.enter().append('g').classed('t0z', true);
|
|
8722
8904
|
t0zEnter.append('line').classed('line', true);
|
|
8723
|
-
t0zEnter.append('
|
|
8905
|
+
t0zEnter.append('line').classed('line touch', true);
|
|
8906
|
+
t0zEnter.append('circle').classed('point touch', true);
|
|
8724
8907
|
// MERGE
|
|
8725
8908
|
const t0zMerge = t0zEnter.merge(t0zUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8726
8909
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8727
|
-
let
|
|
8910
|
+
let {
|
|
8911
|
+
z
|
|
8912
|
+
} = this;
|
|
8728
8913
|
switch (event.key) {
|
|
8729
8914
|
case 'ArrowUp':
|
|
8730
|
-
z += event.shiftKey ?
|
|
8915
|
+
z += event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8731
8916
|
break;
|
|
8732
8917
|
case 'ArrowDown':
|
|
8733
|
-
z -= event.shiftKey ?
|
|
8918
|
+
z -= event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8734
8919
|
break;
|
|
8735
8920
|
}
|
|
8736
8921
|
// Clamp z
|
|
8737
|
-
z = z <
|
|
8922
|
+
z = z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
|
|
8738
8923
|
this.z = z;
|
|
8739
8924
|
this.alignState();
|
|
8740
8925
|
this.dispatchEvent(new CustomEvent('ddm-model-z', {
|
|
@@ -8749,14 +8934,14 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8749
8934
|
let t0 = this.t0; /* eslint-disable-line prefer-destructuring */
|
|
8750
8935
|
switch (event.key) {
|
|
8751
8936
|
case 'ArrowRight':
|
|
8752
|
-
t0 += event.shiftKey ?
|
|
8937
|
+
t0 += event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8753
8938
|
break;
|
|
8754
8939
|
case 'ArrowLeft':
|
|
8755
|
-
t0 -= event.shiftKey ?
|
|
8940
|
+
t0 -= event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8756
8941
|
break;
|
|
8757
8942
|
}
|
|
8758
8943
|
// Clamp t0
|
|
8759
|
-
t0 = t0 <
|
|
8944
|
+
t0 = t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8760
8945
|
this.t0 = t0;
|
|
8761
8946
|
this.alignState();
|
|
8762
8947
|
this.dispatchEvent(new CustomEvent('ddm-model-t0', {
|
|
@@ -8782,6 +8967,13 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8782
8967
|
}).attr('y2', datum => {
|
|
8783
8968
|
return evidenceScale(datum.startingPoint);
|
|
8784
8969
|
});
|
|
8970
|
+
t0zMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(0)).attr('x2', datum => {
|
|
8971
|
+
return timeScale(datum.t0);
|
|
8972
|
+
}).attr('y1', datum => {
|
|
8973
|
+
return evidenceScale(datum.startingPoint);
|
|
8974
|
+
}).attr('y2', datum => {
|
|
8975
|
+
return evidenceScale(datum.startingPoint);
|
|
8976
|
+
});
|
|
8785
8977
|
t0zMerge.select('.point').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('cx', datum => {
|
|
8786
8978
|
return timeScale(datum.t0);
|
|
8787
8979
|
}).attr('cy', datum => {
|
|
@@ -9088,7 +9280,7 @@ class RDK2AFCTask extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
9088
9280
|
this.yScale = undefined; // D3 Scale for y-axis
|
|
9089
9281
|
}
|
|
9090
9282
|
static get styles() {
|
|
9091
|
-
return [super.styles, i$
|
|
9283
|
+
return [super.styles, i$3`
|
|
9092
9284
|
:host {
|
|
9093
9285
|
display: inline-block;
|
|
9094
9286
|
|
|
@@ -9269,7 +9461,7 @@ class RDK2AFCTask extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
9269
9461
|
const queryUpdate = select(this.renderRoot).select('.content').selectAll('.query').data([]);
|
|
9270
9462
|
queryUpdate.exit().remove();
|
|
9271
9463
|
}
|
|
9272
|
-
run(
|
|
9464
|
+
run(/* elapsed */
|
|
9273
9465
|
) {
|
|
9274
9466
|
const realTime = now();
|
|
9275
9467
|
const currentTime = this.baseTime ? realTime - this.baseTime : 0;
|
|
@@ -9465,7 +9657,7 @@ class DDMEquation extends AccumulableElement {
|
|
|
9465
9657
|
this.numeric = false;
|
|
9466
9658
|
}
|
|
9467
9659
|
static get styles() {
|
|
9468
|
-
return [super.styles, i$
|
|
9660
|
+
return [super.styles, i$3`
|
|
9469
9661
|
:host {
|
|
9470
9662
|
display: block;
|
|
9471
9663
|
|
|
@@ -9664,9 +9856,9 @@ class DDMEquationAZV2PC extends DDMEquation {
|
|
|
9664
9856
|
}
|
|
9665
9857
|
constructor() {
|
|
9666
9858
|
super();
|
|
9667
|
-
this.a =
|
|
9668
|
-
this.z =
|
|
9669
|
-
this.v =
|
|
9859
|
+
this.a = DDMMath.a.DEFAULT;
|
|
9860
|
+
this.z = DDMMath.z.DEFAULT;
|
|
9861
|
+
this.v = DDMMath.v.DEFAULT;
|
|
9670
9862
|
this.alignState();
|
|
9671
9863
|
}
|
|
9672
9864
|
alignState() {
|
|
@@ -9708,19 +9900,46 @@ class DDMEquationAZV2PC extends DDMEquation {
|
|
|
9708
9900
|
let s;
|
|
9709
9901
|
let accuracy;
|
|
9710
9902
|
if (this.numeric) {
|
|
9711
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
9903
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
9904
|
+
?disabled=${!this.interactive}
|
|
9905
|
+
min=${DDMMath.a.MIN}
|
|
9906
|
+
max=${DDMMath.a.MAX}
|
|
9907
|
+
step=${DDMMath.a.STEP}
|
|
9908
|
+
.value=${this.a}
|
|
9909
|
+
@input=${this.aInput.bind(this)}
|
|
9910
|
+
>
|
|
9712
9911
|
<var class="math-var">a</var>
|
|
9713
9912
|
</decidables-spinner>`;
|
|
9714
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
9913
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
9914
|
+
?disabled=${!this.interactive}
|
|
9915
|
+
min=${DDMMath.z.MIN}
|
|
9916
|
+
max=${DDMMath.z.MAX}
|
|
9917
|
+
step=${DDMMath.z.STEP}
|
|
9918
|
+
.value=${this.z}
|
|
9919
|
+
@input=${this.zInput.bind(this)}
|
|
9920
|
+
>
|
|
9715
9921
|
<var class="math-var">z</var>
|
|
9716
9922
|
</decidables-spinner>`;
|
|
9717
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
9923
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
9924
|
+
?disabled=${!this.interactive}
|
|
9925
|
+
min=${DDMMath.v.MIN}
|
|
9926
|
+
max=${DDMMath.v.MAX}
|
|
9927
|
+
step=${DDMMath.v.STEP}
|
|
9928
|
+
.value=${this.v}
|
|
9929
|
+
@input=${this.vInput.bind(this)}
|
|
9930
|
+
>
|
|
9718
9931
|
<var class="math-var">v</var>
|
|
9719
9932
|
</decidables-spinner>`;
|
|
9720
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
9933
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
9934
|
+
disabled
|
|
9935
|
+
.value=${DDMMath.s.DEFAULT}
|
|
9936
|
+
>
|
|
9721
9937
|
<var class="math-var">s</var>
|
|
9722
9938
|
</decidables-spinner>`;
|
|
9723
|
-
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9939
|
+
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9940
|
+
disabled
|
|
9941
|
+
.value=${+this.accuracy.toFixed(2)}
|
|
9942
|
+
>
|
|
9724
9943
|
<var>Accuracy</var>
|
|
9725
9944
|
</decidables-spinner>`;
|
|
9726
9945
|
} else {
|
|
@@ -9798,10 +10017,10 @@ class DDMEquationAZVT02M extends DDMEquation {
|
|
|
9798
10017
|
}
|
|
9799
10018
|
constructor() {
|
|
9800
10019
|
super();
|
|
9801
|
-
this.a =
|
|
9802
|
-
this.z =
|
|
9803
|
-
this.v =
|
|
9804
|
-
this.t0 =
|
|
10020
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10021
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10022
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10023
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
9805
10024
|
this.alignState();
|
|
9806
10025
|
}
|
|
9807
10026
|
alignState() {
|
|
@@ -9850,22 +10069,56 @@ class DDMEquationAZVT02M extends DDMEquation {
|
|
|
9850
10069
|
let s;
|
|
9851
10070
|
let meanRT;
|
|
9852
10071
|
if (this.numeric) {
|
|
9853
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
10072
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
10073
|
+
?disabled=${!this.interactive}
|
|
10074
|
+
min=${DDMMath.a.MIN}
|
|
10075
|
+
max=${DDMMath.a.MAX}
|
|
10076
|
+
step=${DDMMath.a.STEP}
|
|
10077
|
+
.value=${this.a}
|
|
10078
|
+
@input=${this.aInput.bind(this)}
|
|
10079
|
+
>
|
|
9854
10080
|
<var class="math-var">a</var>
|
|
9855
10081
|
</decidables-spinner>`;
|
|
9856
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
10082
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
10083
|
+
?disabled=${!this.interactive}
|
|
10084
|
+
min=${DDMMath.z.MIN}
|
|
10085
|
+
max=${DDMMath.z.MAX}
|
|
10086
|
+
step=${DDMMath.z.STEP}
|
|
10087
|
+
.value=${this.z}
|
|
10088
|
+
@input=${this.zInput.bind(this)}
|
|
10089
|
+
>
|
|
9857
10090
|
<var class="math-var">z</var>
|
|
9858
10091
|
</decidables-spinner>`;
|
|
9859
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
10092
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
10093
|
+
?disabled=${!this.interactive}
|
|
10094
|
+
min=${DDMMath.v.MIN}
|
|
10095
|
+
max=${DDMMath.v.MAX}
|
|
10096
|
+
step=${DDMMath.v.STEP}
|
|
10097
|
+
.value=${this.v}
|
|
10098
|
+
@input=${this.vInput.bind(this)}
|
|
10099
|
+
>
|
|
9860
10100
|
<var class="math-var">v</var>
|
|
9861
10101
|
</decidables-spinner>`;
|
|
9862
|
-
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10102
|
+
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10103
|
+
?disabled=${!this.interactive}
|
|
10104
|
+
min=${DDMMath.t0.MIN}
|
|
10105
|
+
max=${DDMMath.t0.MAX}
|
|
10106
|
+
step=${DDMMath.t0.STEP}
|
|
10107
|
+
.value=${this.t0}
|
|
10108
|
+
@input=${this.t0Input.bind(this)}
|
|
10109
|
+
>
|
|
9863
10110
|
<var class="math-var">t<sub>0</sub></var>
|
|
9864
10111
|
</decidables-spinner>`;
|
|
9865
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
10112
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
10113
|
+
disabled
|
|
10114
|
+
.value=${DDMMath.s.DEFAULT}
|
|
10115
|
+
>
|
|
9866
10116
|
<var class="math-var">s</var>
|
|
9867
10117
|
</decidables-spinner>`;
|
|
9868
|
-
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10118
|
+
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10119
|
+
disabled
|
|
10120
|
+
.value=${+this.meanRT.toFixed(0)}
|
|
10121
|
+
>
|
|
9869
10122
|
<var>Mean RT</var>
|
|
9870
10123
|
</decidables-spinner>`;
|
|
9871
10124
|
} else {
|
|
@@ -9929,7 +10182,7 @@ customElements.define('ddm-equation-azvt02m', DDMEquationAZVT02M);
|
|
|
9929
10182
|
*/
|
|
9930
10183
|
class DDMExample extends AccumulableElement {
|
|
9931
10184
|
static get styles() {
|
|
9932
|
-
return [super.styles, i$
|
|
10185
|
+
return [super.styles, i$3`
|
|
9933
10186
|
:host {
|
|
9934
10187
|
---border: var(--border, 1px solid var(---color-border));
|
|
9935
10188
|
display: inline-block;
|
|
@@ -9988,17 +10241,74 @@ class DDMExample extends AccumulableElement {
|
|
|
9988
10241
|
}
|
|
9989
10242
|
customElements.define('ddm-example', DDMExample);
|
|
9990
10243
|
|
|
9991
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
9992
|
-
|
|
9993
|
-
|
|
9994
10244
|
/*
|
|
9995
10245
|
DDMExampleHuman element
|
|
9996
10246
|
<ddm-example-human>
|
|
9997
10247
|
*/
|
|
9998
10248
|
class DDMExampleHuman extends DDMExample {
|
|
10249
|
+
static get properties() {
|
|
10250
|
+
return {
|
|
10251
|
+
trials: {
|
|
10252
|
+
attribute: 'trials',
|
|
10253
|
+
type: Number,
|
|
10254
|
+
reflect: true
|
|
10255
|
+
},
|
|
10256
|
+
duration: {
|
|
10257
|
+
attribute: 'duration',
|
|
10258
|
+
type: Number,
|
|
10259
|
+
reflect: true
|
|
10260
|
+
},
|
|
10261
|
+
coherence: {
|
|
10262
|
+
attribute: 'coherence',
|
|
10263
|
+
type: Number,
|
|
10264
|
+
reflect: true
|
|
10265
|
+
},
|
|
10266
|
+
color: {
|
|
10267
|
+
attribute: 'color',
|
|
10268
|
+
type: String,
|
|
10269
|
+
reflect: true
|
|
10270
|
+
},
|
|
10271
|
+
a: {
|
|
10272
|
+
attribute: false,
|
|
10273
|
+
type: Number,
|
|
10274
|
+
reflect: false
|
|
10275
|
+
},
|
|
10276
|
+
z: {
|
|
10277
|
+
attribute: false,
|
|
10278
|
+
type: Number,
|
|
10279
|
+
reflect: false
|
|
10280
|
+
},
|
|
10281
|
+
v: {
|
|
10282
|
+
attribute: false,
|
|
10283
|
+
type: Number,
|
|
10284
|
+
reflect: false
|
|
10285
|
+
},
|
|
10286
|
+
t0: {
|
|
10287
|
+
attribute: false,
|
|
10288
|
+
type: Number,
|
|
10289
|
+
reflect: false
|
|
10290
|
+
}
|
|
10291
|
+
};
|
|
10292
|
+
}
|
|
9999
10293
|
constructor() {
|
|
10000
10294
|
super();
|
|
10001
|
-
this.
|
|
10295
|
+
this.trials = 10;
|
|
10296
|
+
this.duration = 2000;
|
|
10297
|
+
this.coherence = 0.5;
|
|
10298
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10299
|
+
this.color = 'outcome';
|
|
10300
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10301
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10302
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10303
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10304
|
+
this.accumulableControl = null;
|
|
10305
|
+
this.rdkTask = null;
|
|
10306
|
+
this.accumulableResponse = null;
|
|
10307
|
+
this.accumulableTable = null;
|
|
10308
|
+
this.ddmParameters = null;
|
|
10309
|
+
this.ddmModel = null;
|
|
10310
|
+
this.ddmFit = null;
|
|
10311
|
+
this.data = undefined;
|
|
10002
10312
|
}
|
|
10003
10313
|
connectedCallback() {
|
|
10004
10314
|
super.connectedCallback();
|
|
@@ -10012,57 +10322,32 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10012
10322
|
|
|
10013
10323
|
// Initialize
|
|
10014
10324
|
this.ddmModel.clear();
|
|
10015
|
-
if (this.accumulableControl
|
|
10325
|
+
if (this.accumulableControl) {
|
|
10016
10326
|
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10017
|
-
|
|
10018
|
-
this.rdkTask.trials = event.detail.trials;
|
|
10019
|
-
}
|
|
10020
|
-
if (this.accumulableResponse) {
|
|
10021
|
-
this.accumulableResponse.trialTotal = event.detail.trials;
|
|
10022
|
-
}
|
|
10327
|
+
this.trials = event.detail.trials;
|
|
10023
10328
|
});
|
|
10024
|
-
}
|
|
10025
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('duration')) {
|
|
10026
10329
|
this.accumulableControl.addEventListener('accumulable-control-duration', event => {
|
|
10027
|
-
|
|
10028
|
-
this.rdkTask.duration = event.detail.duration;
|
|
10029
|
-
this.rdkTask.wait = event.detail.duration;
|
|
10030
|
-
this.rdkTask.iti = event.detail.duration;
|
|
10031
|
-
}
|
|
10330
|
+
this.duration = event.detail.duration;
|
|
10032
10331
|
});
|
|
10033
|
-
}
|
|
10034
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('coherence')) {
|
|
10035
10332
|
this.accumulableControl.addEventListener('accumulable-control-coherence', event => {
|
|
10036
|
-
|
|
10037
|
-
this.rdkTask.coherence = event.detail.coherence;
|
|
10038
|
-
}
|
|
10333
|
+
this.coherence = event.detail.coherence;
|
|
10039
10334
|
});
|
|
10040
|
-
}
|
|
10041
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('color')) {
|
|
10042
10335
|
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10043
|
-
|
|
10044
|
-
this.accumulableTable.color = event.detail.color;
|
|
10045
|
-
}
|
|
10336
|
+
this.color = event.detail.color;
|
|
10046
10337
|
});
|
|
10047
|
-
|
|
10048
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('run')) {
|
|
10049
|
-
this.accumulableControl.addEventListener('accumulable-control-run', ( /* event */
|
|
10338
|
+
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10050
10339
|
) => {
|
|
10051
10340
|
if (this.rdkTask) {
|
|
10052
10341
|
this.rdkTask.running = true;
|
|
10053
10342
|
}
|
|
10054
10343
|
});
|
|
10055
|
-
|
|
10056
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('pause')) {
|
|
10057
|
-
this.accumulableControl.addEventListener('accumulable-control-pause', ( /* event */
|
|
10344
|
+
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10058
10345
|
) => {
|
|
10059
10346
|
if (this.rdkTask) {
|
|
10060
10347
|
this.rdkTask.running = false;
|
|
10061
10348
|
}
|
|
10062
10349
|
});
|
|
10063
|
-
|
|
10064
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('reset')) {
|
|
10065
|
-
this.accumulableControl.addEventListener('accumulable-control-reset', ( /* event */
|
|
10350
|
+
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10066
10351
|
) => {
|
|
10067
10352
|
if (this.rdkTask) {
|
|
10068
10353
|
this.rdkTask.reset();
|
|
@@ -10094,11 +10379,6 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10094
10379
|
}
|
|
10095
10380
|
});
|
|
10096
10381
|
}
|
|
10097
|
-
if (this.rdkTask) {
|
|
10098
|
-
if (this.accumulableResponse) {
|
|
10099
|
-
this.accumulableResponse.trialTotal = this.rdkTask.trials;
|
|
10100
|
-
}
|
|
10101
|
-
}
|
|
10102
10382
|
if (this.rdkTask) {
|
|
10103
10383
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
10104
10384
|
if (this.accumulableResponse) {
|
|
@@ -10107,7 +10387,7 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10107
10387
|
});
|
|
10108
10388
|
}
|
|
10109
10389
|
if (this.rdkTask) {
|
|
10110
|
-
this.rdkTask.addEventListener('rdk-trial-end', (
|
|
10390
|
+
this.rdkTask.addEventListener('rdk-trial-end', (/* event */
|
|
10111
10391
|
) => {
|
|
10112
10392
|
if (this.accumulableResponse) {
|
|
10113
10393
|
this.accumulableResponse.stop();
|
|
@@ -10115,7 +10395,7 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10115
10395
|
});
|
|
10116
10396
|
}
|
|
10117
10397
|
if (this.rdkTask) {
|
|
10118
|
-
this.rdkTask.addEventListener('rdk-block-end', (
|
|
10398
|
+
this.rdkTask.addEventListener('rdk-block-end', (/* event */
|
|
10119
10399
|
) => {
|
|
10120
10400
|
if (this.accumulableControl) {
|
|
10121
10401
|
this.accumulableControl.complete();
|
|
@@ -10124,18 +10404,7 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10124
10404
|
}
|
|
10125
10405
|
if (this.accumulableResponse) {
|
|
10126
10406
|
this.accumulableResponse.addEventListener('accumulable-response', event => {
|
|
10127
|
-
|
|
10128
|
-
this.accumulableTable.correctCount = event.detail.correctCount;
|
|
10129
|
-
this.accumulableTable.errorCount = event.detail.errorCount;
|
|
10130
|
-
this.accumulableTable.nrCount = event.detail.nrCount;
|
|
10131
|
-
this.accumulableTable.accuracy = event.detail.accuracy;
|
|
10132
|
-
this.accumulableTable.correctMeanRT = event.detail.correctMeanRT;
|
|
10133
|
-
this.accumulableTable.errorMeanRT = event.detail.errorMeanRT;
|
|
10134
|
-
this.accumulableTable.meanRT = event.detail.meanRT;
|
|
10135
|
-
this.accumulableTable.correctSDRT = event.detail.correctSDRT;
|
|
10136
|
-
this.accumulableTable.errorSDRT = event.detail.errorSDRT;
|
|
10137
|
-
this.accumulableTable.sdRT = event.detail.sdRT;
|
|
10138
|
-
}
|
|
10407
|
+
this.data = event.detail.data;
|
|
10139
10408
|
if (this.ddmModel) {
|
|
10140
10409
|
this.ddmModel.trial({
|
|
10141
10410
|
index: event.detail.trial,
|
|
@@ -10145,34 +10414,73 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10145
10414
|
}
|
|
10146
10415
|
if (this.ddmFit) {
|
|
10147
10416
|
this.ddmFit.set({
|
|
10148
|
-
accuracy: event.detail.accuracy,
|
|
10149
|
-
correctMeanRT: event.detail.correctMeanRT,
|
|
10150
|
-
errorMeanRT: event.detail.errorMeanRT,
|
|
10151
|
-
meanRT: event.detail.meanRT,
|
|
10152
|
-
correctSDRT: event.detail.correctSDRT,
|
|
10153
|
-
errorSDRT: event.detail.errorSDRT,
|
|
10154
|
-
sdRT: event.detail.sdRT
|
|
10417
|
+
accuracy: event.detail.data.accuracy,
|
|
10418
|
+
correctMeanRT: event.detail.data.correctMeanRT,
|
|
10419
|
+
errorMeanRT: event.detail.data.errorMeanRT,
|
|
10420
|
+
meanRT: event.detail.data.meanRT,
|
|
10421
|
+
correctSDRT: event.detail.data.correctSDRT,
|
|
10422
|
+
errorSDRT: event.detail.data.errorSDRT,
|
|
10423
|
+
sdRT: event.detail.data.sdRT
|
|
10155
10424
|
});
|
|
10156
10425
|
}
|
|
10426
|
+
this.requestUpdate();
|
|
10157
10427
|
});
|
|
10158
10428
|
}
|
|
10159
10429
|
if (this.ddmFit) {
|
|
10160
10430
|
this.ddmFit.addEventListener('ddm-fit-update', event => {
|
|
10161
|
-
|
|
10162
|
-
|
|
10163
|
-
|
|
10164
|
-
|
|
10165
|
-
this.ddmParameters.t0 = event.detail.t0;
|
|
10166
|
-
}
|
|
10167
|
-
if (this.ddmModel) {
|
|
10168
|
-
this.ddmModel.a = event.detail.a;
|
|
10169
|
-
this.ddmModel.z = 0.5; // event.detail.z;
|
|
10170
|
-
this.ddmModel.v = event.detail.v;
|
|
10171
|
-
this.ddmModel.t0 = event.detail.t0;
|
|
10172
|
-
}
|
|
10431
|
+
this.a = event.detail.a;
|
|
10432
|
+
this.z = 0.5; // event.detail.z;
|
|
10433
|
+
this.v = event.detail.v;
|
|
10434
|
+
this.t0 = event.detail.t0;
|
|
10173
10435
|
});
|
|
10174
10436
|
}
|
|
10175
10437
|
}
|
|
10438
|
+
update(changedProperties) {
|
|
10439
|
+
super.update(changedProperties);
|
|
10440
|
+
if (this.accumulableControl) {
|
|
10441
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10442
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10443
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10444
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10445
|
+
}
|
|
10446
|
+
if (this.rdkTask) {
|
|
10447
|
+
this.rdkTask.trials = this.trials;
|
|
10448
|
+
this.rdkTask.duration = this.duration;
|
|
10449
|
+
this.rdkTask.wait = this.duration;
|
|
10450
|
+
this.rdkTask.iti = this.duration;
|
|
10451
|
+
this.rdkTask.coherence = this.coherence;
|
|
10452
|
+
}
|
|
10453
|
+
if (this.ddmParameters) {
|
|
10454
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10455
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10456
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10457
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10458
|
+
}
|
|
10459
|
+
if (this.ddmModel) {
|
|
10460
|
+
this.ddmModel.a = +this.a;
|
|
10461
|
+
this.ddmModel.z = +this.z;
|
|
10462
|
+
this.ddmModel.v = +this.v;
|
|
10463
|
+
this.ddmModel.t0 = +this.t0;
|
|
10464
|
+
}
|
|
10465
|
+
if (this.accumulableResponse) {
|
|
10466
|
+
this.accumulableResponse.trialTotal = this.trials;
|
|
10467
|
+
}
|
|
10468
|
+
if (this.accumulableTable) {
|
|
10469
|
+
this.accumulableTable.color = this.color;
|
|
10470
|
+
}
|
|
10471
|
+
if (this.accumulableTable && this.data) {
|
|
10472
|
+
this.accumulableTable.correctCount = this.data.correctCount;
|
|
10473
|
+
this.accumulableTable.errorCount = this.data.errorCount;
|
|
10474
|
+
this.accumulableTable.nrCount = this.data.nrCount;
|
|
10475
|
+
this.accumulableTable.accuracy = this.data.accuracy;
|
|
10476
|
+
this.accumulableTable.correctMeanRT = this.data.correctMeanRT;
|
|
10477
|
+
this.accumulableTable.errorMeanRT = this.data.errorMeanRT;
|
|
10478
|
+
this.accumulableTable.meanRT = this.data.meanRT;
|
|
10479
|
+
this.accumulableTable.correctSDRT = this.data.correctSDRT;
|
|
10480
|
+
this.accumulableTable.errorSDRT = this.data.errorSDRT;
|
|
10481
|
+
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10482
|
+
}
|
|
10483
|
+
}
|
|
10176
10484
|
}
|
|
10177
10485
|
customElements.define('ddm-example-human', DDMExampleHuman);
|
|
10178
10486
|
|
|
@@ -10188,6 +10496,11 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10188
10496
|
type: Number,
|
|
10189
10497
|
reflect: true
|
|
10190
10498
|
},
|
|
10499
|
+
color: {
|
|
10500
|
+
attribute: 'color',
|
|
10501
|
+
type: String,
|
|
10502
|
+
reflect: true
|
|
10503
|
+
},
|
|
10191
10504
|
a: {
|
|
10192
10505
|
attribute: 'boundary-separation',
|
|
10193
10506
|
type: Number,
|
|
@@ -10213,10 +10526,12 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10213
10526
|
constructor() {
|
|
10214
10527
|
super();
|
|
10215
10528
|
this.trials = 10;
|
|
10216
|
-
this.
|
|
10217
|
-
this.
|
|
10218
|
-
this.
|
|
10219
|
-
this.
|
|
10529
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10530
|
+
this.color = 'outcome';
|
|
10531
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10532
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10533
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10534
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10220
10535
|
this.accumulableControl = null;
|
|
10221
10536
|
this.accumulableTable = null;
|
|
10222
10537
|
this.ddmParameters = null;
|
|
@@ -10231,7 +10546,7 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10231
10546
|
this.ddmParameters = this.querySelector('ddm-parameters');
|
|
10232
10547
|
this.ddmModel = this.querySelector('ddm-model');
|
|
10233
10548
|
if (this.accumulableControl) {
|
|
10234
|
-
this.accumulableControl.addEventListener('accumulable-control-resample', (
|
|
10549
|
+
this.accumulableControl.addEventListener('accumulable-control-resample', (/* event */
|
|
10235
10550
|
) => {
|
|
10236
10551
|
this.ddmModel?.resample();
|
|
10237
10552
|
this.requestUpdate();
|
|
@@ -10239,6 +10554,9 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10239
10554
|
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10240
10555
|
this.trials = event.detail.trials;
|
|
10241
10556
|
});
|
|
10557
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10558
|
+
this.color = event.detail.color;
|
|
10559
|
+
});
|
|
10242
10560
|
}
|
|
10243
10561
|
if (this.ddmParameters) {
|
|
10244
10562
|
this.ddmParameters.addEventListener('ddm-parameters-a', event => {
|
|
@@ -10278,7 +10596,11 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10278
10596
|
update(changedProperties) {
|
|
10279
10597
|
super.update(changedProperties);
|
|
10280
10598
|
if (this.accumulableControl) {
|
|
10281
|
-
this.accumulableControl.trials = this.trials;
|
|
10599
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10600
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10601
|
+
}
|
|
10602
|
+
if (this.accumulableTable) {
|
|
10603
|
+
this.accumulableTable.color = this.color;
|
|
10282
10604
|
}
|
|
10283
10605
|
if (this.accumulableTable && this.data) {
|
|
10284
10606
|
this.accumulableTable.correctCount = this.data.correctCount;
|
|
@@ -10293,10 +10615,10 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10293
10615
|
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10294
10616
|
}
|
|
10295
10617
|
if (this.ddmParameters) {
|
|
10296
|
-
this.ddmParameters.a = this.a;
|
|
10297
|
-
this.ddmParameters.z = this.z;
|
|
10298
|
-
this.ddmParameters.v = this.v;
|
|
10299
|
-
this.ddmParameters.t0 = this.t0;
|
|
10618
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10619
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10620
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10621
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10300
10622
|
}
|
|
10301
10623
|
if (this.ddmModel) {
|
|
10302
10624
|
this.ddmModel.trials = this.trials;
|
|
@@ -10309,9 +10631,6 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10309
10631
|
}
|
|
10310
10632
|
customElements.define('ddm-example-interactive', DDMExampleInteractive);
|
|
10311
10633
|
|
|
10312
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
10313
|
-
|
|
10314
|
-
|
|
10315
10634
|
/*
|
|
10316
10635
|
DDMExampleModel element
|
|
10317
10636
|
<ddm-example-model>
|
|
@@ -10368,10 +10687,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10368
10687
|
this.coherence = 0.5;
|
|
10369
10688
|
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10370
10689
|
this.color = 'outcome';
|
|
10371
|
-
this.a =
|
|
10372
|
-
this.z =
|
|
10373
|
-
this.v =
|
|
10374
|
-
this.t0 =
|
|
10690
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10691
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10692
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10693
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10375
10694
|
this.accumulableControl = null;
|
|
10376
10695
|
this.rdkTask = null;
|
|
10377
10696
|
this.ddmParameters = null;
|
|
@@ -10393,60 +10712,48 @@ class DDMExampleModel extends DDMExample {
|
|
|
10393
10712
|
this.accumulableResponse = this.querySelector('accumulable-response');
|
|
10394
10713
|
this.accumulableTable = this.querySelector('accumulable-table');
|
|
10395
10714
|
if (this.accumulableControl) {
|
|
10396
|
-
|
|
10397
|
-
this.
|
|
10398
|
-
|
|
10399
|
-
|
|
10400
|
-
|
|
10401
|
-
|
|
10402
|
-
|
|
10403
|
-
|
|
10404
|
-
|
|
10405
|
-
|
|
10406
|
-
|
|
10407
|
-
this.
|
|
10408
|
-
this.
|
|
10409
|
-
}
|
|
10410
|
-
|
|
10411
|
-
|
|
10412
|
-
|
|
10413
|
-
|
|
10414
|
-
|
|
10415
|
-
|
|
10416
|
-
|
|
10417
|
-
|
|
10418
|
-
|
|
10419
|
-
|
|
10420
|
-
|
|
10421
|
-
|
|
10422
|
-
|
|
10423
|
-
|
|
10424
|
-
|
|
10425
|
-
|
|
10426
|
-
|
|
10427
|
-
|
|
10428
|
-
|
|
10429
|
-
|
|
10430
|
-
|
|
10431
|
-
|
|
10432
|
-
|
|
10433
|
-
|
|
10434
|
-
|
|
10435
|
-
|
|
10436
|
-
|
|
10437
|
-
|
|
10438
|
-
if (this.rdkTask) {
|
|
10439
|
-
this.rdkTask.reset();
|
|
10440
|
-
}
|
|
10441
|
-
if (this.ddmModel) {
|
|
10442
|
-
this.ddmModel.trials = this.trialCount;
|
|
10443
|
-
}
|
|
10444
|
-
if (this.accumulableResponse) {
|
|
10445
|
-
this.accumulableResponse.reset();
|
|
10446
|
-
}
|
|
10447
|
-
if (this.accumulableTable) ;
|
|
10448
|
-
});
|
|
10449
|
-
}
|
|
10715
|
+
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10716
|
+
this.trials = event.detail.trials;
|
|
10717
|
+
});
|
|
10718
|
+
this.accumulableControl.addEventListener('accumulable-control-duration', event => {
|
|
10719
|
+
this.duration = event.detail.duration;
|
|
10720
|
+
});
|
|
10721
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10722
|
+
this.color = event.detail.color;
|
|
10723
|
+
});
|
|
10724
|
+
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10725
|
+
) => {
|
|
10726
|
+
if (this.rdkTask) {
|
|
10727
|
+
this.rdkTask.running = true;
|
|
10728
|
+
}
|
|
10729
|
+
if (this.ddmModel) {
|
|
10730
|
+
this.ddmModel.resumeTrial();
|
|
10731
|
+
}
|
|
10732
|
+
});
|
|
10733
|
+
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10734
|
+
) => {
|
|
10735
|
+
if (this.rdkTask) {
|
|
10736
|
+
this.rdkTask.running = false;
|
|
10737
|
+
}
|
|
10738
|
+
if (this.ddmModel) {
|
|
10739
|
+
this.ddmModel.pauseTrial();
|
|
10740
|
+
}
|
|
10741
|
+
});
|
|
10742
|
+
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10743
|
+
) => {
|
|
10744
|
+
this.trialCount = 0;
|
|
10745
|
+
this.signal = undefined;
|
|
10746
|
+
if (this.rdkTask) {
|
|
10747
|
+
this.rdkTask.reset();
|
|
10748
|
+
}
|
|
10749
|
+
if (this.ddmModel) {
|
|
10750
|
+
this.ddmModel.trials = this.trialCount;
|
|
10751
|
+
}
|
|
10752
|
+
if (this.accumulableResponse) {
|
|
10753
|
+
this.accumulableResponse.reset();
|
|
10754
|
+
}
|
|
10755
|
+
if (this.accumulableTable) ;
|
|
10756
|
+
});
|
|
10450
10757
|
}
|
|
10451
10758
|
if (this.rdkTask) {
|
|
10452
10759
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
@@ -10459,14 +10766,14 @@ class DDMExampleModel extends DDMExample {
|
|
|
10459
10766
|
this.ddmModel.trial();
|
|
10460
10767
|
}
|
|
10461
10768
|
});
|
|
10462
|
-
this.rdkTask.addEventListener('rdk-trial-end', (
|
|
10769
|
+
this.rdkTask.addEventListener('rdk-trial-end', (/* event */
|
|
10463
10770
|
) => {
|
|
10464
10771
|
this.signal = undefined;
|
|
10465
10772
|
if (this.accumulableResponse) {
|
|
10466
10773
|
this.accumulableResponse.stop();
|
|
10467
10774
|
}
|
|
10468
10775
|
});
|
|
10469
|
-
this.rdkTask.addEventListener('rdk-block-end', (
|
|
10776
|
+
this.rdkTask.addEventListener('rdk-block-end', (/* event */
|
|
10470
10777
|
) => {
|
|
10471
10778
|
if (this.accumulableControl) {
|
|
10472
10779
|
this.accumulableControl.complete();
|
|
@@ -10505,17 +10812,15 @@ class DDMExampleModel extends DDMExample {
|
|
|
10505
10812
|
this.model = event.detail.model;
|
|
10506
10813
|
this.requestUpdate();
|
|
10507
10814
|
});
|
|
10508
|
-
|
|
10509
|
-
this.
|
|
10510
|
-
|
|
10511
|
-
|
|
10512
|
-
|
|
10513
|
-
|
|
10514
|
-
|
|
10515
|
-
|
|
10516
|
-
|
|
10517
|
-
});
|
|
10518
|
-
}
|
|
10815
|
+
this.ddmModel.addEventListener('accumulable-response', event => {
|
|
10816
|
+
if (this.accumulableResponse) {
|
|
10817
|
+
const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
|
|
10818
|
+
this.accumulableResponse.responded(response);
|
|
10819
|
+
}
|
|
10820
|
+
this.data = event.detail.data;
|
|
10821
|
+
this.model = event.detail.model;
|
|
10822
|
+
this.requestUpdate();
|
|
10823
|
+
});
|
|
10519
10824
|
}
|
|
10520
10825
|
this.requestUpdate();
|
|
10521
10826
|
}
|
|
@@ -10525,10 +10830,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10525
10830
|
this.trialCount = this.trials;
|
|
10526
10831
|
}
|
|
10527
10832
|
if (this.accumulableControl) {
|
|
10528
|
-
this.accumulableControl.trials = this.trials;
|
|
10529
|
-
this.accumulableControl.duration = this.duration;
|
|
10530
|
-
this.accumulableControl.coherence = this.coherence;
|
|
10531
|
-
this.accumulableControl.color = this.color;
|
|
10833
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10834
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10835
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10836
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10532
10837
|
}
|
|
10533
10838
|
if (this.rdkTask) {
|
|
10534
10839
|
this.rdkTask.trials = this.trials;
|
|
@@ -10536,10 +10841,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10536
10841
|
this.rdkTask.coherence = this.coherence;
|
|
10537
10842
|
}
|
|
10538
10843
|
if (this.ddmParameters) {
|
|
10539
|
-
this.ddmParameters.a = this.a;
|
|
10540
|
-
this.ddmParameters.z = this.z;
|
|
10541
|
-
this.ddmParameters.v = this.v;
|
|
10542
|
-
this.ddmParameters.t0 = this.t0;
|
|
10844
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10845
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10846
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10847
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10543
10848
|
}
|
|
10544
10849
|
if (this.ddmModel) {
|
|
10545
10850
|
this.ddmModel.trials = this.trialCount;
|