@decidables/accumulable-elements 0.1.3 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +28 -0
- package/README.md +72 -33
- package/lib/accumulableElements.esm.js +733 -415
- package/lib/accumulableElements.esm.js.map +1 -1
- package/lib/accumulableElements.esm.min.js +300 -125
- package/lib/accumulableElements.esm.min.js.map +1 -1
- package/lib/accumulableElements.umd.js +733 -415
- package/lib/accumulableElements.umd.js.map +1 -1
- package/lib/accumulableElements.umd.min.js +301 -126
- package/lib/accumulableElements.umd.min.js.map +1 -1
- package/package.json +8 -8
- package/src/components/accumulable-control.js +4 -4
- package/src/components/accumulable-response.js +6 -24
- package/src/components/ddm-fit-worker.js +2 -2
- package/src/components/ddm-fit.js +6 -4
- package/src/components/ddm-model.js +130 -62
- package/src/components/ddm-parameters.js +61 -4
- package/src/equations/azv2pc.js +35 -8
- package/src/equations/azvt02m.js +44 -10
- package/src/examples/human.js +156 -71
- package/src/examples/interactive.js +39 -9
- package/src/examples/model.js +95 -93
|
@@ -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$
|
|
9
|
-
o$
|
|
7
|
+
e$2 = t$1.ShadowRoot && (void 0 === t$1.ShadyCSS || t$1.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
|
|
8
|
+
s$2 = Symbol(),
|
|
9
|
+
o$4 = new WeakMap();
|
|
10
10
|
let n$2 = class n {
|
|
11
11
|
constructor(t, e, o) {
|
|
12
|
-
if (this._$cssResult$ = true, o !== s$
|
|
12
|
+
if (this._$cssResult$ = true, o !== s$2) 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$
|
|
18
|
+
if (e$2 && void 0 === t) {
|
|
19
|
+
const e = void 0 !== s && 1 === s.length;
|
|
20
|
+
e && (t = o$4.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$4.set(s, t));
|
|
21
21
|
}
|
|
22
22
|
return t;
|
|
23
23
|
}
|
|
@@ -25,26 +25,26 @@ let n$2 = class n {
|
|
|
25
25
|
return this.cssText;
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
-
const r$
|
|
28
|
+
const r$2 = t => new n$2("string" == typeof t ? t : t + "", void 0, s$2),
|
|
29
29
|
i$3 = (t, ...e) => {
|
|
30
30
|
const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
|
|
31
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$2);
|
|
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
|
+
void 0 !== 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 => {
|
|
45
45
|
let e = "";
|
|
46
46
|
for (const s of t.cssRules) e += s.cssText;
|
|
47
|
-
return r$
|
|
47
|
+
return r$2(e);
|
|
48
48
|
})(t) : t;
|
|
49
49
|
|
|
50
50
|
/**
|
|
@@ -55,9 +55,9 @@ const r$3 = t => new n$2("string" == typeof t ? t : t + "", undefined, s$1),
|
|
|
55
55
|
const {
|
|
56
56
|
is: i$2,
|
|
57
57
|
defineProperty: e$1,
|
|
58
|
-
getOwnPropertyDescriptor:
|
|
59
|
-
getOwnPropertyNames:
|
|
60
|
-
getOwnPropertySymbols: o$
|
|
58
|
+
getOwnPropertyDescriptor: h$1,
|
|
59
|
+
getOwnPropertyNames: r$1,
|
|
60
|
+
getOwnPropertySymbols: o$3,
|
|
61
61
|
getPrototypeOf: n$1
|
|
62
62
|
} = Object,
|
|
63
63
|
a$1 = globalThis,
|
|
@@ -98,33 +98,34 @@ const {
|
|
|
98
98
|
}
|
|
99
99
|
},
|
|
100
100
|
f$1 = (t, s) => !i$2(t, s),
|
|
101
|
-
|
|
101
|
+
b$1 = {
|
|
102
102
|
attribute: true,
|
|
103
103
|
type: String,
|
|
104
104
|
converter: u$1,
|
|
105
105
|
reflect: false,
|
|
106
|
+
useDefault: false,
|
|
106
107
|
hasChanged: f$1
|
|
107
108
|
};
|
|
108
109
|
Symbol.metadata ??= Symbol("metadata"), a$1.litPropertyMetadata ??= new WeakMap();
|
|
109
|
-
let
|
|
110
|
+
let y$2 = class y extends HTMLElement {
|
|
110
111
|
static addInitializer(t) {
|
|
111
112
|
this._$Ei(), (this.l ??= []).push(t);
|
|
112
113
|
}
|
|
113
114
|
static get observedAttributes() {
|
|
114
115
|
return this.finalize(), this._$Eh && [...this._$Eh.keys()];
|
|
115
116
|
}
|
|
116
|
-
static createProperty(t, s =
|
|
117
|
-
if (s.state && (s.attribute = false), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
|
|
117
|
+
static createProperty(t, s = b$1) {
|
|
118
|
+
if (s.state && (s.attribute = false), this._$Ei(), this.prototype.hasOwnProperty(t) && ((s = Object.create(s)).wrapped = true), this.elementProperties.set(t, s), !s.noAccessor) {
|
|
118
119
|
const i = Symbol(),
|
|
119
|
-
|
|
120
|
-
|
|
120
|
+
h = this.getPropertyDescriptor(t, i, s);
|
|
121
|
+
void 0 !== h && e$1(this.prototype, t, h);
|
|
121
122
|
}
|
|
122
123
|
}
|
|
123
124
|
static getPropertyDescriptor(t, s, i) {
|
|
124
125
|
const {
|
|
125
126
|
get: e,
|
|
126
|
-
set:
|
|
127
|
-
} =
|
|
127
|
+
set: r
|
|
128
|
+
} = h$1(this.prototype, t) ?? {
|
|
128
129
|
get() {
|
|
129
130
|
return this[s];
|
|
130
131
|
},
|
|
@@ -133,41 +134,39 @@ let b$1 = class b extends HTMLElement {
|
|
|
133
134
|
}
|
|
134
135
|
};
|
|
135
136
|
return {
|
|
136
|
-
get
|
|
137
|
-
return e?.call(this);
|
|
138
|
-
},
|
|
137
|
+
get: e,
|
|
139
138
|
set(s) {
|
|
140
|
-
const
|
|
141
|
-
|
|
139
|
+
const h = e?.call(this);
|
|
140
|
+
r?.call(this, s), this.requestUpdate(t, h, i);
|
|
142
141
|
},
|
|
143
142
|
configurable: true,
|
|
144
143
|
enumerable: true
|
|
145
144
|
};
|
|
146
145
|
}
|
|
147
146
|
static getPropertyOptions(t) {
|
|
148
|
-
return this.elementProperties.get(t) ??
|
|
147
|
+
return this.elementProperties.get(t) ?? b$1;
|
|
149
148
|
}
|
|
150
149
|
static _$Ei() {
|
|
151
150
|
if (this.hasOwnProperty(d$1("elementProperties"))) return;
|
|
152
151
|
const t = n$1(this);
|
|
153
|
-
t.finalize(),
|
|
152
|
+
t.finalize(), void 0 !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
|
|
154
153
|
}
|
|
155
154
|
static finalize() {
|
|
156
155
|
if (this.hasOwnProperty(d$1("finalized"))) return;
|
|
157
156
|
if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
|
|
158
157
|
const t = this.properties,
|
|
159
|
-
s = [...
|
|
158
|
+
s = [...r$1(t), ...o$3(t)];
|
|
160
159
|
for (const i of s) this.createProperty(i, t[i]);
|
|
161
160
|
}
|
|
162
161
|
const t = this[Symbol.metadata];
|
|
163
162
|
if (null !== t) {
|
|
164
163
|
const s = litPropertyMetadata.get(t);
|
|
165
|
-
if (
|
|
164
|
+
if (void 0 !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
|
|
166
165
|
}
|
|
167
166
|
this._$Eh = new Map();
|
|
168
167
|
for (const [t, s] of this.elementProperties) {
|
|
169
168
|
const i = this._$Eu(t, s);
|
|
170
|
-
|
|
169
|
+
void 0 !== i && this._$Eh.set(i, t);
|
|
171
170
|
}
|
|
172
171
|
this.elementStyles = this.finalizeStyles(this.styles);
|
|
173
172
|
}
|
|
@@ -176,21 +175,21 @@ let b$1 = class b extends HTMLElement {
|
|
|
176
175
|
if (Array.isArray(s)) {
|
|
177
176
|
const e = new Set(s.flat(1 / 0).reverse());
|
|
178
177
|
for (const s of e) i.unshift(c$2(s));
|
|
179
|
-
} else
|
|
178
|
+
} else void 0 !== s && i.push(c$2(s));
|
|
180
179
|
return i;
|
|
181
180
|
}
|
|
182
181
|
static _$Eu(t, s) {
|
|
183
182
|
const i = s.attribute;
|
|
184
|
-
return false === i ?
|
|
183
|
+
return false === i ? void 0 : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : void 0;
|
|
185
184
|
}
|
|
186
185
|
constructor() {
|
|
187
|
-
super(), this._$Ep =
|
|
186
|
+
super(), this._$Ep = void 0, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
|
|
188
187
|
}
|
|
189
188
|
_$Ev() {
|
|
190
189
|
this._$ES = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
|
|
191
190
|
}
|
|
192
191
|
addController(t) {
|
|
193
|
-
(this._$EO ??= new Set()).add(t),
|
|
192
|
+
(this._$EO ??= new Set()).add(t), void 0 !== this.renderRoot && this.isConnected && t.hostConnected?.();
|
|
194
193
|
}
|
|
195
194
|
removeController(t) {
|
|
196
195
|
this._$EO?.delete(t);
|
|
@@ -215,36 +214,44 @@ let b$1 = class b extends HTMLElement {
|
|
|
215
214
|
attributeChangedCallback(t, s, i) {
|
|
216
215
|
this._$AK(t, i);
|
|
217
216
|
}
|
|
218
|
-
_$
|
|
217
|
+
_$ET(t, s) {
|
|
219
218
|
const i = this.constructor.elementProperties.get(t),
|
|
220
219
|
e = this.constructor._$Eu(t, i);
|
|
221
|
-
if (
|
|
222
|
-
const
|
|
223
|
-
this._$Em = t, null ==
|
|
220
|
+
if (void 0 !== e && true === i.reflect) {
|
|
221
|
+
const h = (void 0 !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
|
|
222
|
+
this._$Em = t, null == h ? this.removeAttribute(e) : this.setAttribute(e, h), this._$Em = null;
|
|
224
223
|
}
|
|
225
224
|
}
|
|
226
225
|
_$AK(t, s) {
|
|
227
226
|
const i = this.constructor,
|
|
228
227
|
e = i._$Eh.get(t);
|
|
229
|
-
if (
|
|
228
|
+
if (void 0 !== e && this._$Em !== e) {
|
|
230
229
|
const t = i.getPropertyOptions(e),
|
|
231
|
-
|
|
230
|
+
h = "function" == typeof t.converter ? {
|
|
232
231
|
fromAttribute: t.converter
|
|
233
|
-
} :
|
|
234
|
-
this._$Em = e
|
|
232
|
+
} : void 0 !== t.converter?.fromAttribute ? t.converter : u$1;
|
|
233
|
+
this._$Em = e;
|
|
234
|
+
const r = h.fromAttribute(s, t.type);
|
|
235
|
+
this[e] = r ?? this._$Ej?.get(e) ?? r, this._$Em = null;
|
|
235
236
|
}
|
|
236
237
|
}
|
|
237
238
|
requestUpdate(t, s, i) {
|
|
238
|
-
if (
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
239
|
+
if (void 0 !== t) {
|
|
240
|
+
const e = this.constructor,
|
|
241
|
+
h = this[t];
|
|
242
|
+
if (i ??= e.getPropertyOptions(t), !((i.hasChanged ?? f$1)(h, s) || i.useDefault && i.reflect && h === this._$Ej?.get(t) && !this.hasAttribute(e._$Eu(t, i)))) return;
|
|
243
|
+
this.C(t, s, i);
|
|
244
|
+
}
|
|
245
|
+
false === this.isUpdatePending && (this._$ES = this._$EP());
|
|
246
|
+
}
|
|
247
|
+
C(t, s, {
|
|
248
|
+
useDefault: i,
|
|
249
|
+
reflect: e,
|
|
250
|
+
wrapped: h
|
|
251
|
+
}, r) {
|
|
252
|
+
i && !(this._$Ej ??= new Map()).has(t) && (this._$Ej.set(t, r ?? s ?? this[t]), true !== h || void 0 !== r) || (this._$AL.has(t) || (this.hasUpdated || i || (s = void 0), this._$AL.set(t, s)), true === e && this._$Em !== t && (this._$Eq ??= new Set()).add(t));
|
|
253
|
+
}
|
|
254
|
+
async _$EP() {
|
|
248
255
|
this.isUpdatePending = true;
|
|
249
256
|
try {
|
|
250
257
|
await this._$ES;
|
|
@@ -262,17 +269,23 @@ let b$1 = class b extends HTMLElement {
|
|
|
262
269
|
if (!this.hasUpdated) {
|
|
263
270
|
if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
|
|
264
271
|
for (const [t, s] of this._$Ep) this[t] = s;
|
|
265
|
-
this._$Ep =
|
|
272
|
+
this._$Ep = void 0;
|
|
266
273
|
}
|
|
267
274
|
const t = this.constructor.elementProperties;
|
|
268
|
-
if (t.size > 0) for (const [s, i] of t)
|
|
275
|
+
if (t.size > 0) for (const [s, i] of t) {
|
|
276
|
+
const {
|
|
277
|
+
wrapped: t
|
|
278
|
+
} = i,
|
|
279
|
+
e = this[s];
|
|
280
|
+
true !== t || this._$AL.has(s) || void 0 === e || this.C(s, void 0, i, e);
|
|
281
|
+
}
|
|
269
282
|
}
|
|
270
283
|
let t = false;
|
|
271
284
|
const s = this._$AL;
|
|
272
285
|
try {
|
|
273
|
-
t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$
|
|
286
|
+
t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EM();
|
|
274
287
|
} catch (s) {
|
|
275
|
-
throw t = false, this._$
|
|
288
|
+
throw t = false, this._$EM(), s;
|
|
276
289
|
}
|
|
277
290
|
t && this._$AE(s);
|
|
278
291
|
}
|
|
@@ -280,7 +293,7 @@ let b$1 = class b extends HTMLElement {
|
|
|
280
293
|
_$AE(t) {
|
|
281
294
|
this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t)), this.updated(t);
|
|
282
295
|
}
|
|
283
|
-
_$
|
|
296
|
+
_$EM() {
|
|
284
297
|
this._$AL = new Map(), this.isUpdatePending = false;
|
|
285
298
|
}
|
|
286
299
|
get updateComplete() {
|
|
@@ -293,16 +306,16 @@ let b$1 = class b extends HTMLElement {
|
|
|
293
306
|
return true;
|
|
294
307
|
}
|
|
295
308
|
update(t) {
|
|
296
|
-
this._$
|
|
309
|
+
this._$Eq &&= this._$Eq.forEach(t => this._$ET(t, this[t])), this._$EM();
|
|
297
310
|
}
|
|
298
311
|
updated(t) {}
|
|
299
312
|
firstUpdated(t) {}
|
|
300
313
|
};
|
|
301
|
-
|
|
314
|
+
y$2.elementStyles = [], y$2.shadowRootOptions = {
|
|
302
315
|
mode: "open"
|
|
303
|
-
},
|
|
304
|
-
ReactiveElement:
|
|
305
|
-
}), (a$1.reactiveElementVersions ??= []).push("2.
|
|
316
|
+
}, y$2[d$1("elementProperties")] = new Map(), y$2[d$1("finalized")] = new Map(), p$1?.({
|
|
317
|
+
ReactiveElement: y$2
|
|
318
|
+
}), (a$1.reactiveElementVersions ??= []).push("2.1.1");
|
|
306
319
|
|
|
307
320
|
/**
|
|
308
321
|
* @license
|
|
@@ -311,15 +324,15 @@ b$1.elementStyles = [], b$1.shadowRootOptions = {
|
|
|
311
324
|
*/
|
|
312
325
|
const t = globalThis,
|
|
313
326
|
i$1 = t.trustedTypes,
|
|
314
|
-
s = i$1 ? i$1.createPolicy("lit-html", {
|
|
327
|
+
s$1 = i$1 ? i$1.createPolicy("lit-html", {
|
|
315
328
|
createHTML: t => t
|
|
316
|
-
}) :
|
|
329
|
+
}) : void 0,
|
|
317
330
|
e = "$lit$",
|
|
318
331
|
h = `lit$${Math.random().toFixed(9).slice(2)}$`,
|
|
319
|
-
o$
|
|
320
|
-
n = `<${o$
|
|
321
|
-
r
|
|
322
|
-
l = () => r
|
|
332
|
+
o$2 = "?" + h,
|
|
333
|
+
n = `<${o$2}>`,
|
|
334
|
+
r = document,
|
|
335
|
+
l = () => r.createComment(""),
|
|
323
336
|
c = t => null === t || "object" != typeof t && "function" != typeof t,
|
|
324
337
|
a = Array.isArray,
|
|
325
338
|
u = t => a(t) || "function" == typeof t?.[Symbol.iterator],
|
|
@@ -341,10 +354,10 @@ const t = globalThis,
|
|
|
341
354
|
T = Symbol.for("lit-noChange"),
|
|
342
355
|
E = Symbol.for("lit-nothing"),
|
|
343
356
|
A = new WeakMap(),
|
|
344
|
-
C = r
|
|
357
|
+
C = r.createTreeWalker(r, 129);
|
|
345
358
|
function P(t, i) {
|
|
346
359
|
if (!a(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
|
|
347
|
-
return
|
|
360
|
+
return void 0 !== s$1 ? s$1.createHTML(i) : i;
|
|
348
361
|
}
|
|
349
362
|
const V = (t, i) => {
|
|
350
363
|
const s = t.length - 1,
|
|
@@ -358,7 +371,7 @@ const V = (t, i) => {
|
|
|
358
371
|
u,
|
|
359
372
|
d = -1,
|
|
360
373
|
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 :
|
|
374
|
+
for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v : void 0 !== u[1] ? c = _ : void 0 !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : void 0 !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f, d = -1) : void 0 === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = void 0 === u[3] ? m : '"' === u[3] ? g : p) : c === g || c === p ? c = m : c === v || c === _ ? c = f : (c = m, r = void 0);
|
|
362
375
|
const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
|
|
363
376
|
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
377
|
}
|
|
@@ -409,7 +422,7 @@ class N {
|
|
|
409
422
|
r.append(t[s], l());
|
|
410
423
|
}
|
|
411
424
|
}
|
|
412
|
-
} else if (8 === r.nodeType) if (r.data === o$
|
|
425
|
+
} else if (8 === r.nodeType) if (r.data === o$2) d.push({
|
|
413
426
|
type: 2,
|
|
414
427
|
index: c
|
|
415
428
|
});else {
|
|
@@ -423,19 +436,19 @@ class N {
|
|
|
423
436
|
}
|
|
424
437
|
}
|
|
425
438
|
static createElement(t, i) {
|
|
426
|
-
const s = r
|
|
439
|
+
const s = r.createElement("template");
|
|
427
440
|
return s.innerHTML = t, s;
|
|
428
441
|
}
|
|
429
442
|
}
|
|
430
443
|
function S(t, i, s = t, e) {
|
|
431
444
|
if (i === T) return i;
|
|
432
|
-
let h =
|
|
433
|
-
const o = c(i) ?
|
|
434
|
-
return h?.constructor !== o && (h?._$AO?.(false),
|
|
445
|
+
let h = void 0 !== e ? s._$Co?.[e] : s._$Cl;
|
|
446
|
+
const o = c(i) ? void 0 : i._$litDirective$;
|
|
447
|
+
return h?.constructor !== o && (h?._$AO?.(false), void 0 === o ? h = void 0 : (h = new o(t), h._$AT(t, s, e)), void 0 !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), void 0 !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
|
|
435
448
|
}
|
|
436
449
|
class M {
|
|
437
450
|
constructor(t, i) {
|
|
438
|
-
this._$AV = [], this._$AN =
|
|
451
|
+
this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = i;
|
|
439
452
|
}
|
|
440
453
|
get parentNode() {
|
|
441
454
|
return this._$AM.parentNode;
|
|
@@ -450,24 +463,24 @@ class M {
|
|
|
450
463
|
},
|
|
451
464
|
parts: s
|
|
452
465
|
} = this._$AD,
|
|
453
|
-
e = (t?.creationScope ?? r
|
|
466
|
+
e = (t?.creationScope ?? r).importNode(i, true);
|
|
454
467
|
C.currentNode = e;
|
|
455
468
|
let h = C.nextNode(),
|
|
456
469
|
o = 0,
|
|
457
470
|
n = 0,
|
|
458
471
|
l = s[0];
|
|
459
|
-
for (;
|
|
472
|
+
for (; void 0 !== l;) {
|
|
460
473
|
if (o === l.index) {
|
|
461
474
|
let i;
|
|
462
475
|
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
476
|
}
|
|
464
477
|
o !== l?.index && (h = C.nextNode(), o++);
|
|
465
478
|
}
|
|
466
|
-
return C.currentNode = r
|
|
479
|
+
return C.currentNode = r, e;
|
|
467
480
|
}
|
|
468
481
|
p(t) {
|
|
469
482
|
let i = 0;
|
|
470
|
-
for (const s of this._$AV)
|
|
483
|
+
for (const s of this._$AV) void 0 !== s && (void 0 !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
|
|
471
484
|
}
|
|
472
485
|
}
|
|
473
486
|
class R {
|
|
@@ -475,12 +488,12 @@ class R {
|
|
|
475
488
|
return this._$AM?._$AU ?? this._$Cv;
|
|
476
489
|
}
|
|
477
490
|
constructor(t, i, s, e) {
|
|
478
|
-
this.type = 2, this._$AH = E, this._$AN =
|
|
491
|
+
this.type = 2, this._$AH = E, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
|
|
479
492
|
}
|
|
480
493
|
get parentNode() {
|
|
481
494
|
let t = this._$AA.parentNode;
|
|
482
495
|
const i = this._$AM;
|
|
483
|
-
return
|
|
496
|
+
return void 0 !== i && 11 === t?.nodeType && (t = i.parentNode), t;
|
|
484
497
|
}
|
|
485
498
|
get startNode() {
|
|
486
499
|
return this._$AA;
|
|
@@ -489,7 +502,7 @@ class R {
|
|
|
489
502
|
return this._$AB;
|
|
490
503
|
}
|
|
491
504
|
_$AI(t, i = this) {
|
|
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) :
|
|
505
|
+
t = S(this, t, i), c(t) ? t === E || null == t || "" === t ? (this._$AH !== E && this._$AR(), this._$AH = E) : t !== this._$AH && t !== T && this._(t) : void 0 !== t._$litType$ ? this.$(t) : void 0 !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
|
|
493
506
|
}
|
|
494
507
|
O(t) {
|
|
495
508
|
return this._$AA.parentNode.insertBefore(t, this._$AB);
|
|
@@ -498,14 +511,14 @@ class R {
|
|
|
498
511
|
this._$AH !== t && (this._$AR(), this._$AH = this.O(t));
|
|
499
512
|
}
|
|
500
513
|
_(t) {
|
|
501
|
-
this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r
|
|
514
|
+
this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r.createTextNode(t)), this._$AH = t;
|
|
502
515
|
}
|
|
503
516
|
$(t) {
|
|
504
517
|
const {
|
|
505
518
|
values: i,
|
|
506
519
|
_$litType$: s
|
|
507
520
|
} = t,
|
|
508
|
-
e = "number" == typeof s ? this._$AC(t) : (
|
|
521
|
+
e = "number" == typeof s ? this._$AC(t) : (void 0 === s.el && (s.el = N.createElement(P(s.h, s.h[0]), this.options)), s);
|
|
509
522
|
if (this._$AH?._$AD === e) this._$AH.p(i);else {
|
|
510
523
|
const t = new M(e, this),
|
|
511
524
|
s = t.u(this.options);
|
|
@@ -514,7 +527,7 @@ class R {
|
|
|
514
527
|
}
|
|
515
528
|
_$AC(t) {
|
|
516
529
|
let i = A.get(t.strings);
|
|
517
|
-
return
|
|
530
|
+
return void 0 === i && A.set(t.strings, i = new N(t)), i;
|
|
518
531
|
}
|
|
519
532
|
k(t) {
|
|
520
533
|
a(this._$AH) || (this._$AH = [], this._$AR());
|
|
@@ -525,13 +538,13 @@ class R {
|
|
|
525
538
|
e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
|
|
526
539
|
}
|
|
527
540
|
_$AR(t = this._$AA.nextSibling, i) {
|
|
528
|
-
for (this._$AP?.(false, true, i); t
|
|
541
|
+
for (this._$AP?.(false, true, i); t !== this._$AB;) {
|
|
529
542
|
const i = t.nextSibling;
|
|
530
543
|
t.remove(), t = i;
|
|
531
544
|
}
|
|
532
545
|
}
|
|
533
546
|
setConnected(t) {
|
|
534
|
-
|
|
547
|
+
void 0 === this._$AM && (this._$Cv = t, this._$AP?.(t));
|
|
535
548
|
}
|
|
536
549
|
}
|
|
537
550
|
class k {
|
|
@@ -542,12 +555,12 @@ class k {
|
|
|
542
555
|
return this._$AM._$AU;
|
|
543
556
|
}
|
|
544
557
|
constructor(t, i, s, e, h) {
|
|
545
|
-
this.type = 1, this._$AH = E, this._$AN =
|
|
558
|
+
this.type = 1, this._$AH = E, this._$AN = void 0, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E;
|
|
546
559
|
}
|
|
547
560
|
_$AI(t, i = this, s, e) {
|
|
548
561
|
const h = this.strings;
|
|
549
562
|
let o = false;
|
|
550
|
-
if (
|
|
563
|
+
if (void 0 === h) t = S(this, t, i, 0), o = !c(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
|
|
551
564
|
const e = t;
|
|
552
565
|
let n, r;
|
|
553
566
|
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;
|
|
@@ -563,7 +576,7 @@ class H extends k {
|
|
|
563
576
|
super(...arguments), this.type = 3;
|
|
564
577
|
}
|
|
565
578
|
j(t) {
|
|
566
|
-
this.element[this.name] = t === E ?
|
|
579
|
+
this.element[this.name] = t === E ? void 0 : t;
|
|
567
580
|
}
|
|
568
581
|
}
|
|
569
582
|
class I extends k {
|
|
@@ -591,7 +604,7 @@ class L extends k {
|
|
|
591
604
|
}
|
|
592
605
|
class z {
|
|
593
606
|
constructor(t, i, s) {
|
|
594
|
-
this.element = t, this.type = 6, this._$AN =
|
|
607
|
+
this.element = t, this.type = 6, this._$AN = void 0, this._$AM = i, this.options = s;
|
|
595
608
|
}
|
|
596
609
|
get _$AU() {
|
|
597
610
|
return this._$AM._$AU;
|
|
@@ -601,13 +614,13 @@ class z {
|
|
|
601
614
|
}
|
|
602
615
|
}
|
|
603
616
|
const j = t.litHtmlPolyfillSupport;
|
|
604
|
-
j?.(N, R), (t.litHtmlVersions ??= []).push("3.
|
|
617
|
+
j?.(N, R), (t.litHtmlVersions ??= []).push("3.3.1");
|
|
605
618
|
const B = (t, i, s) => {
|
|
606
619
|
const e = s?.renderBefore ?? i;
|
|
607
620
|
let h = e._$litPart$;
|
|
608
|
-
if (
|
|
621
|
+
if (void 0 === h) {
|
|
609
622
|
const t = s?.renderBefore ?? null;
|
|
610
|
-
e._$litPart$ = h = new R(i.insertBefore(l(), t), t,
|
|
623
|
+
e._$litPart$ = h = new R(i.insertBefore(l(), t), t, void 0, s ?? {});
|
|
611
624
|
}
|
|
612
625
|
return h._$AI(t), h;
|
|
613
626
|
};
|
|
@@ -617,19 +630,20 @@ const B = (t, i, s) => {
|
|
|
617
630
|
* Copyright 2017 Google LLC
|
|
618
631
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
619
632
|
*/
|
|
620
|
-
|
|
633
|
+
const s = globalThis;
|
|
634
|
+
class i extends y$2 {
|
|
621
635
|
constructor() {
|
|
622
636
|
super(...arguments), this.renderOptions = {
|
|
623
637
|
host: this
|
|
624
|
-
}, this._$Do =
|
|
638
|
+
}, this._$Do = void 0;
|
|
625
639
|
}
|
|
626
640
|
createRenderRoot() {
|
|
627
641
|
const t = super.createRenderRoot();
|
|
628
642
|
return this.renderOptions.renderBefore ??= t.firstChild, t;
|
|
629
643
|
}
|
|
630
644
|
update(t) {
|
|
631
|
-
const
|
|
632
|
-
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(
|
|
645
|
+
const r = this.render();
|
|
646
|
+
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(r, this.renderRoot, this.renderOptions);
|
|
633
647
|
}
|
|
634
648
|
connectedCallback() {
|
|
635
649
|
super.connectedCallback(), this._$Do?.setConnected(true);
|
|
@@ -641,14 +655,14 @@ class r extends b$1 {
|
|
|
641
655
|
return T;
|
|
642
656
|
}
|
|
643
657
|
}
|
|
644
|
-
|
|
645
|
-
LitElement:
|
|
658
|
+
i._$litElement$ = true, i["finalized"] = true, s.litElementHydrateSupport?.({
|
|
659
|
+
LitElement: i
|
|
646
660
|
});
|
|
647
|
-
const
|
|
648
|
-
|
|
649
|
-
LitElement:
|
|
661
|
+
const o$1 = s.litElementPolyfillSupport;
|
|
662
|
+
o$1?.({
|
|
663
|
+
LitElement: i
|
|
650
664
|
});
|
|
651
|
-
(
|
|
665
|
+
(s.litElementVersions ??= []).push("4.2.1");
|
|
652
666
|
|
|
653
667
|
function ascending$1(a, b) {
|
|
654
668
|
return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
|
|
@@ -4566,7 +4580,7 @@ Transform.prototype;
|
|
|
4566
4580
|
DecidablesElement Base Class - Not intended for instantiation!
|
|
4567
4581
|
<decidables-element>
|
|
4568
4582
|
*/
|
|
4569
|
-
class DecidablesElement extends
|
|
4583
|
+
class DecidablesElement extends i {
|
|
4570
4584
|
getComputedStyleValue(property) {
|
|
4571
4585
|
return getComputedStyle(this).getPropertyValue(property).trim();
|
|
4572
4586
|
}
|
|
@@ -4821,22 +4835,22 @@ class DecidablesElement extends r {
|
|
|
4821
4835
|
static get styles() {
|
|
4822
4836
|
return i$3`
|
|
4823
4837
|
:host {
|
|
4824
|
-
---shadow-0: var(--shadow-0, ${r$
|
|
4825
|
-
---shadow-2: var(--shadow-2, ${r$
|
|
4826
|
-
---shadow-4: var(--shadow-4, ${r$
|
|
4827
|
-
---shadow-8: var(--shadow-8, ${r$
|
|
4828
|
-
|
|
4829
|
-
---color-background: var(--color-background, ${r$
|
|
4830
|
-
---color-border: var(--color-border, ${r$
|
|
4831
|
-
---color-text: var(--color-text, ${r$
|
|
4832
|
-
---color-text-inverse: var(--color-text-inverse, ${r$
|
|
4833
|
-
---color-link: var(--color-link, ${r$
|
|
4834
|
-
---color-element-background: var(--color-element-background, ${r$
|
|
4835
|
-
---color-element-disabled: var(--color-element-disabled, ${r$
|
|
4836
|
-
---color-element-enabled: var(--color-element-enabled, ${r$
|
|
4837
|
-
---color-element-selected: var(--color-element-selected, ${r$
|
|
4838
|
-
---color-element-border: var(--color-element-border, ${r$
|
|
4839
|
-
---color-element-emphasis: var(--color-element-emphasis, ${r$
|
|
4838
|
+
---shadow-0: var(--shadow-0, ${r$2(this.cssBoxShadow(0))});
|
|
4839
|
+
---shadow-2: var(--shadow-2, ${r$2(this.cssBoxShadow(2))});
|
|
4840
|
+
---shadow-4: var(--shadow-4, ${r$2(this.cssBoxShadow(4))});
|
|
4841
|
+
---shadow-8: var(--shadow-8, ${r$2(this.cssBoxShadow(8))});
|
|
4842
|
+
|
|
4843
|
+
---color-background: var(--color-background, ${r$2(this.greys.white)});
|
|
4844
|
+
---color-border: var(--color-border, ${r$2(this.greys.light75)});
|
|
4845
|
+
---color-text: var(--color-text, ${r$2(this.greys.dark75)});
|
|
4846
|
+
---color-text-inverse: var(--color-text-inverse, ${r$2(this.greys.white)});
|
|
4847
|
+
---color-link: var(--color-link, ${r$2(this.greys.dark25)});
|
|
4848
|
+
---color-element-background: var(--color-element-background, ${r$2(this.greys.light75)});
|
|
4849
|
+
---color-element-disabled: var(--color-element-disabled, ${r$2(this.greys.light50)});
|
|
4850
|
+
---color-element-enabled: var(--color-element-enabled, ${r$2(this.greys.dark25)});
|
|
4851
|
+
---color-element-selected: var(--color-element-selected, ${r$2(this.greys.grey)});
|
|
4852
|
+
---color-element-border: var(--color-element-border, ${r$2(this.greys.dark50)});
|
|
4853
|
+
---color-element-emphasis: var(--color-element-emphasis, ${r$2(this.greys.dark75)});
|
|
4840
4854
|
|
|
4841
4855
|
---font-family-base: var(--font-family-base, "Source Sans", sans-serif);
|
|
4842
4856
|
---font-family-math: var(--font-family-math, "Source Serif", serif);
|
|
@@ -4846,6 +4860,7 @@ class DecidablesElement extends r {
|
|
|
4846
4860
|
---transition-duration: var(--transition-duration, 500ms);
|
|
4847
4861
|
|
|
4848
4862
|
font-family: var(---font-family-base);
|
|
4863
|
+
font-weight: normal;
|
|
4849
4864
|
}
|
|
4850
4865
|
|
|
4851
4866
|
:host,
|
|
@@ -4899,6 +4914,9 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4899
4914
|
static get styles() {
|
|
4900
4915
|
return [super.styles, i$3`
|
|
4901
4916
|
:host {
|
|
4917
|
+
---decidables-button-background-color-disabled: var(--decidables-button-background-color, var(---color-element-disabled));
|
|
4918
|
+
---decidables-button-background-color-enabled: var(--decidables-button-background-color, var(---color-element-enabled));
|
|
4919
|
+
|
|
4902
4920
|
margin: 0.25rem;
|
|
4903
4921
|
}
|
|
4904
4922
|
|
|
@@ -4918,7 +4936,7 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4918
4936
|
}
|
|
4919
4937
|
|
|
4920
4938
|
button:disabled {
|
|
4921
|
-
background-color: var(
|
|
4939
|
+
background-color: var(---decidables-button-background-color-disabled);
|
|
4922
4940
|
outline: none;
|
|
4923
4941
|
box-shadow: none;
|
|
4924
4942
|
}
|
|
@@ -4926,7 +4944,7 @@ class DecidablesButton extends DecidablesElement {
|
|
|
4926
4944
|
button:enabled {
|
|
4927
4945
|
cursor: pointer;
|
|
4928
4946
|
|
|
4929
|
-
background-color: var(
|
|
4947
|
+
background-color: var(---decidables-button-background-color-enabled);
|
|
4930
4948
|
outline: none;
|
|
4931
4949
|
box-shadow: var(---shadow-2);
|
|
4932
4950
|
}
|
|
@@ -4977,6 +4995,11 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
4977
4995
|
type: Boolean,
|
|
4978
4996
|
reflect: true
|
|
4979
4997
|
},
|
|
4998
|
+
scale: {
|
|
4999
|
+
attribute: 'scale',
|
|
5000
|
+
type: Boolean,
|
|
5001
|
+
reflect: true
|
|
5002
|
+
},
|
|
4980
5003
|
max: {
|
|
4981
5004
|
attribute: 'max',
|
|
4982
5005
|
type: Number,
|
|
@@ -4996,6 +5019,11 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
4996
5019
|
attribute: 'value',
|
|
4997
5020
|
type: Number,
|
|
4998
5021
|
reflect: true
|
|
5022
|
+
},
|
|
5023
|
+
nonlinear: {
|
|
5024
|
+
attribute: false,
|
|
5025
|
+
type: Boolean,
|
|
5026
|
+
reflect: false
|
|
4999
5027
|
}
|
|
5000
5028
|
};
|
|
5001
5029
|
}
|
|
@@ -5004,13 +5032,30 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5004
5032
|
|
|
5005
5033
|
// Attributes
|
|
5006
5034
|
this.disabled = false;
|
|
5035
|
+
this.scale = false;
|
|
5007
5036
|
this.max = undefined;
|
|
5008
5037
|
this.min = undefined;
|
|
5009
5038
|
this.step = undefined;
|
|
5010
5039
|
this.value = undefined;
|
|
5011
|
-
|
|
5012
|
-
|
|
5013
|
-
|
|
5040
|
+
this.nonlinear = false;
|
|
5041
|
+
|
|
5042
|
+
// Properties
|
|
5043
|
+
this.rangeMax = undefined;
|
|
5044
|
+
this.rangeMin = undefined;
|
|
5045
|
+
this.rangeStep = undefined;
|
|
5046
|
+
this.rangeValue = undefined;
|
|
5047
|
+
|
|
5048
|
+
// Transform
|
|
5049
|
+
this.toRange = undefined;
|
|
5050
|
+
this.fromRange = undefined;
|
|
5051
|
+
}
|
|
5052
|
+
nonlinearRange(nonlinear, toRange, fromRange) {
|
|
5053
|
+
this.nonlinear = nonlinear;
|
|
5054
|
+
this.toRange = nonlinear ? toRange : undefined;
|
|
5055
|
+
this.fromRange = nonlinear ? fromRange : undefined;
|
|
5056
|
+
}
|
|
5057
|
+
rangeChanged(event) {
|
|
5058
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5014
5059
|
this.dispatchEvent(new CustomEvent('change', {
|
|
5015
5060
|
detail: {
|
|
5016
5061
|
value: this.value
|
|
@@ -5018,15 +5063,28 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5018
5063
|
bubbles: true
|
|
5019
5064
|
}));
|
|
5020
5065
|
}
|
|
5021
|
-
|
|
5066
|
+
rangeInputted(event) {
|
|
5067
|
+
this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
|
|
5068
|
+
}
|
|
5069
|
+
spinnerInputted(event) {
|
|
5022
5070
|
this.value = event.target.value;
|
|
5023
5071
|
}
|
|
5072
|
+
willUpdate() {
|
|
5073
|
+
this.rangeMax = this.max === undefined ? undefined : this.nonlinear ? this.toRange(this.max) : this.max;
|
|
5074
|
+
this.rangeMin = this.min === undefined ? undefined : this.nonlinear ? this.toRange(this.min) : this.min;
|
|
5075
|
+
this.rangeStep = this.step === undefined ? undefined : this.nonlinear ? 'any' : this.step;
|
|
5076
|
+
this.rangeValue = this.value === undefined ? undefined : this.nonlinear ? this.toRange(this.value) : this.value;
|
|
5077
|
+
}
|
|
5024
5078
|
static get styles() {
|
|
5025
5079
|
return [super.styles, i$3`
|
|
5026
5080
|
:host {
|
|
5027
|
-
---
|
|
5028
|
-
---
|
|
5029
|
-
---
|
|
5081
|
+
---decidables-slider-background-color: var(--decidables-slider-background-color, var(---color-element-disabled));
|
|
5082
|
+
---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
|
|
5083
|
+
---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
|
|
5084
|
+
|
|
5085
|
+
---shadow-2-rotate: var(--shadow-2-rotate, ${r$2(this.cssBoxShadow(2, true, false))});
|
|
5086
|
+
---shadow-4-rotate: var(--shadow-4-rotate, ${r$2(this.cssBoxShadow(4, true, false))});
|
|
5087
|
+
---shadow-8-rotate: var(--shadow-8-rotate, ${r$2(this.cssBoxShadow(8, true, false))});
|
|
5030
5088
|
|
|
5031
5089
|
display: flex;
|
|
5032
5090
|
|
|
@@ -5041,7 +5099,10 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5041
5099
|
}
|
|
5042
5100
|
|
|
5043
5101
|
.range {
|
|
5044
|
-
|
|
5102
|
+
position: relative;
|
|
5103
|
+
display: flex;
|
|
5104
|
+
|
|
5105
|
+
flex-direction: row;
|
|
5045
5106
|
|
|
5046
5107
|
width: 3.5rem;
|
|
5047
5108
|
height: 4.75rem;
|
|
@@ -5052,6 +5113,8 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5052
5113
|
--decidables-spinner-input-width: 3.5rem;
|
|
5053
5114
|
|
|
5054
5115
|
margin: 0 0.25rem 0.25rem;
|
|
5116
|
+
|
|
5117
|
+
background: var(---decidables-spinner-background-color);
|
|
5055
5118
|
}
|
|
5056
5119
|
|
|
5057
5120
|
/* Adapted from http://danielstern.ca/range.css/#/ */
|
|
@@ -5090,14 +5153,14 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5090
5153
|
width: 100%;
|
|
5091
5154
|
height: 4px;
|
|
5092
5155
|
|
|
5093
|
-
background: var(---
|
|
5156
|
+
background: var(---decidables-slider-background-color);
|
|
5094
5157
|
border: 0;
|
|
5095
5158
|
border-radius: 2px;
|
|
5096
5159
|
box-shadow: none;
|
|
5097
5160
|
}
|
|
5098
5161
|
|
|
5099
5162
|
input[type=range]:focus::-webkit-slider-runnable-track {
|
|
5100
|
-
background: var(---
|
|
5163
|
+
background: var(---decidables-slider-background-color);
|
|
5101
5164
|
}
|
|
5102
5165
|
|
|
5103
5166
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
@@ -5105,7 +5168,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5105
5168
|
width: 100%;
|
|
5106
5169
|
height: 4px;
|
|
5107
5170
|
|
|
5108
|
-
background: var(---
|
|
5171
|
+
background: var(---decidables-slider-background-color);
|
|
5109
5172
|
border: 0;
|
|
5110
5173
|
border-radius: 2px;
|
|
5111
5174
|
box-shadow: none;
|
|
@@ -5125,7 +5188,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5125
5188
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5126
5189
|
input[type=range]::-ms-fill-lower {
|
|
5127
5190
|
background: #cccccc;
|
|
5128
|
-
/* background: var(---
|
|
5191
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5129
5192
|
border: 0;
|
|
5130
5193
|
border-radius: 2px;
|
|
5131
5194
|
box-shadow: none;
|
|
@@ -5134,7 +5197,7 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5134
5197
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5135
5198
|
input[type=range]::-ms-fill-upper {
|
|
5136
5199
|
background: #cccccc;
|
|
5137
|
-
/* background: var(---
|
|
5200
|
+
/* background: var(---decidables-slider-background-color); */
|
|
5138
5201
|
border: 0;
|
|
5139
5202
|
border-radius: 2px;
|
|
5140
5203
|
box-shadow: none;
|
|
@@ -5142,12 +5205,12 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5142
5205
|
|
|
5143
5206
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5144
5207
|
input[type=range]:focus::-ms-fill-lower {
|
|
5145
|
-
background: var(---
|
|
5208
|
+
background: var(---decidables-slider-background-color);
|
|
5146
5209
|
}
|
|
5147
5210
|
|
|
5148
5211
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5149
5212
|
input[type=range]:focus::-ms-fill-upper {
|
|
5150
|
-
background: var(---
|
|
5213
|
+
background: var(---decidables-slider-background-color);
|
|
5151
5214
|
}
|
|
5152
5215
|
|
|
5153
5216
|
/* Thumb */
|
|
@@ -5165,12 +5228,12 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5165
5228
|
}
|
|
5166
5229
|
|
|
5167
5230
|
input[type=range]:disabled::-webkit-slider-thumb {
|
|
5168
|
-
background: var(---
|
|
5231
|
+
background: var(---decidables-slider-background-color);
|
|
5169
5232
|
box-shadow: none;
|
|
5170
5233
|
}
|
|
5171
5234
|
|
|
5172
5235
|
input[type=range]:enabled::-webkit-slider-thumb {
|
|
5173
|
-
background: var(---
|
|
5236
|
+
background: var(---decidables-slider-color);
|
|
5174
5237
|
box-shadow: var(---shadow-2-rotate);
|
|
5175
5238
|
}
|
|
5176
5239
|
|
|
@@ -5201,13 +5264,13 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5201
5264
|
|
|
5202
5265
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5203
5266
|
input[type=range]:disabled::-moz-range-thumb {
|
|
5204
|
-
background: var(---
|
|
5267
|
+
background: var(---decidables-slider-background-color);
|
|
5205
5268
|
box-shadow: none;
|
|
5206
5269
|
}
|
|
5207
5270
|
|
|
5208
5271
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5209
5272
|
input[type=range]:enabled::-moz-range-thumb {
|
|
5210
|
-
background: var(---
|
|
5273
|
+
background: var(---decidables-slider-color);
|
|
5211
5274
|
box-shadow: var(---shadow-2-rotate);
|
|
5212
5275
|
}
|
|
5213
5276
|
|
|
@@ -5244,13 +5307,13 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5244
5307
|
|
|
5245
5308
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5246
5309
|
input[type=range]:disabled::-ms-thumb {
|
|
5247
|
-
background: var(---
|
|
5310
|
+
background: var(---decidables-slider-background-color);
|
|
5248
5311
|
box-shadow: none;
|
|
5249
5312
|
}
|
|
5250
5313
|
|
|
5251
5314
|
/* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
|
|
5252
5315
|
input[type=range]:enabled::-ms-thumb {
|
|
5253
|
-
background: var(---
|
|
5316
|
+
background: var(---decidables-slider-color);
|
|
5254
5317
|
box-shadow: var(---shadow-2-rotate);
|
|
5255
5318
|
}
|
|
5256
5319
|
|
|
@@ -5272,6 +5335,33 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5272
5335
|
:host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {
|
|
5273
5336
|
box-shadow: var(---shadow-8-rotate);
|
|
5274
5337
|
}
|
|
5338
|
+
|
|
5339
|
+
datalist {
|
|
5340
|
+
position: absolute;
|
|
5341
|
+
left: 2rem;
|
|
5342
|
+
z-index: -1;
|
|
5343
|
+
display: flex;
|
|
5344
|
+
|
|
5345
|
+
flex-direction: column;
|
|
5346
|
+
|
|
5347
|
+
align-items: flex-start;
|
|
5348
|
+
justify-content: space-between;
|
|
5349
|
+
|
|
5350
|
+
height: 4.75rem;
|
|
5351
|
+
|
|
5352
|
+
font-size: 0.75rem;
|
|
5353
|
+
}
|
|
5354
|
+
|
|
5355
|
+
option {
|
|
5356
|
+
padding: 0;
|
|
5357
|
+
|
|
5358
|
+
line-height: 0.8;
|
|
5359
|
+
min-block-size: 0;
|
|
5360
|
+
}
|
|
5361
|
+
|
|
5362
|
+
option::before {
|
|
5363
|
+
content: "– ";
|
|
5364
|
+
}
|
|
5275
5365
|
`];
|
|
5276
5366
|
}
|
|
5277
5367
|
render() {
|
|
@@ -5280,9 +5370,15 @@ class DecidablesSlider extends DecidablesElement {
|
|
|
5280
5370
|
<slot></slot>
|
|
5281
5371
|
</label>
|
|
5282
5372
|
<div class="range">
|
|
5283
|
-
<input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.
|
|
5373
|
+
<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)}>
|
|
5374
|
+
${this.scale ? x$1`
|
|
5375
|
+
<datalist id="ticks">
|
|
5376
|
+
<option value=${o(this.rangeMax)} label=${o(this.max)}></option>
|
|
5377
|
+
<option value=${o(this.rangeMin)} label=${o(this.min)}></option>
|
|
5378
|
+
</datalist>
|
|
5379
|
+
` : x$1``}
|
|
5284
5380
|
</div>
|
|
5285
|
-
<decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.
|
|
5381
|
+
<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
5382
|
`;
|
|
5287
5383
|
}
|
|
5288
5384
|
}
|
|
@@ -5491,7 +5587,6 @@ class DecidablesSwitch extends DecidablesElement {
|
|
|
5491
5587
|
padding: 0;
|
|
5492
5588
|
margin: -1px;
|
|
5493
5589
|
overflow: hidden;
|
|
5494
|
-
clip: rect(0 0 0 0);
|
|
5495
5590
|
|
|
5496
5591
|
white-space: nowrap;
|
|
5497
5592
|
|
|
@@ -5713,7 +5808,6 @@ class DecidablesToggleOption extends DecidablesElement {
|
|
|
5713
5808
|
padding: 0;
|
|
5714
5809
|
margin: -1px;
|
|
5715
5810
|
overflow: hidden;
|
|
5716
|
-
clip: rect(0 0 0 0);
|
|
5717
5811
|
|
|
5718
5812
|
white-space: nowrap;
|
|
5719
5813
|
|
|
@@ -5896,17 +5990,17 @@ class AccumulableElement extends DecidablesElement {
|
|
|
5896
5990
|
return [super.styles, i$3`
|
|
5897
5991
|
:host {
|
|
5898
5992
|
/* Declare base colors */
|
|
5899
|
-
${r$
|
|
5993
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5900
5994
|
return `---color-${color}: var(--color-${color}, ${this.colors[color]});`;
|
|
5901
5995
|
}).join('\n'))}
|
|
5902
5996
|
|
|
5903
5997
|
/* Declare light colors */
|
|
5904
|
-
${r$
|
|
5998
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5905
5999
|
return `---color-${color}-light: var(--color-${color}-light, ${this.lights[color]});`;
|
|
5906
6000
|
}).join('\n'))}
|
|
5907
6001
|
|
|
5908
6002
|
/* Declare dark colors */
|
|
5909
|
-
${r$
|
|
6003
|
+
${r$2(Object.keys(AccumulableElement.colors).map(color => {
|
|
5910
6004
|
return `---color-${color}-dark: var(--color-${color}-dark, ${this.darks[color]});`;
|
|
5911
6005
|
}).join('\n'))}
|
|
5912
6006
|
}
|
|
@@ -6083,15 +6177,15 @@ class AccumulableControl extends AccumulableElement {
|
|
|
6083
6177
|
render() {
|
|
6084
6178
|
return x$1`
|
|
6085
6179
|
<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``}
|
|
6180
|
+
${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
6181
|
${this.resample ? x$1`
|
|
6088
6182
|
<div class="buttons">
|
|
6089
6183
|
${this.resample ? x$1`<decidables-button name="resample" @click=${this.doResample.bind(this)}>Resample</decidables-button>` : x$1``}
|
|
6090
6184
|
</div>
|
|
6091
6185
|
` : 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
|
|
6186
|
+
${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``}
|
|
6187
|
+
${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``}
|
|
6188
|
+
${this.color != null ? x$1`
|
|
6095
6189
|
<decidables-toggle class="color" @change=${this.chooseColor.bind(this)}>
|
|
6096
6190
|
<span slot="label">Emphasis</span>
|
|
6097
6191
|
<decidables-toggle-option name="toggle" value="none" ?checked=${this.color === 'none'}>None</decidables-toggle-option>
|
|
@@ -6116,13 +6210,13 @@ customElements.define('accumulable-control', AccumulableControl);
|
|
|
6116
6210
|
DDMMath Static Class - Not intended for instantiation!
|
|
6117
6211
|
|
|
6118
6212
|
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)
|
|
6213
|
+
a = boundary separation [0, Infinity)
|
|
6214
|
+
z = starting point as a proportion of a (0, 1)
|
|
6215
|
+
v = drift rate (per second) (-Infinity, Infinity)
|
|
6216
|
+
t0 = non-decision time (in milliseconds) (0, Infinity)
|
|
6217
|
+
s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)
|
|
6124
6218
|
|
|
6125
|
-
zPrime = starting point on a 0-to-a scale (typically used in published equations)
|
|
6219
|
+
zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)
|
|
6126
6220
|
|
|
6127
6221
|
Behavioral variables:
|
|
6128
6222
|
pE = proportion of error trials
|
|
@@ -6142,7 +6236,37 @@ customElements.define('accumulable-control', AccumulableControl);
|
|
|
6142
6236
|
EZ-diffusion model (Wagenmakers et al., 2007)
|
|
6143
6237
|
*/
|
|
6144
6238
|
class DDMMath {
|
|
6145
|
-
static s =
|
|
6239
|
+
static s = {
|
|
6240
|
+
DEFAULT: 1
|
|
6241
|
+
};
|
|
6242
|
+
static a = {
|
|
6243
|
+
DEFAULT: 1.2,
|
|
6244
|
+
MIN: 0.01,
|
|
6245
|
+
MAX: 2.0,
|
|
6246
|
+
STEP: 0.01,
|
|
6247
|
+
JUMP: 0.1
|
|
6248
|
+
};
|
|
6249
|
+
static z = {
|
|
6250
|
+
DEFAULT: 0.55,
|
|
6251
|
+
MIN: 0.01,
|
|
6252
|
+
MAX: 0.99,
|
|
6253
|
+
STEP: 0.01,
|
|
6254
|
+
JUMP: 0.1
|
|
6255
|
+
};
|
|
6256
|
+
static v = {
|
|
6257
|
+
DEFAULT: 1.5,
|
|
6258
|
+
MIN: 0.01,
|
|
6259
|
+
MAX: 5.0,
|
|
6260
|
+
STEP: 0.01,
|
|
6261
|
+
JUMP: 0.1
|
|
6262
|
+
};
|
|
6263
|
+
static t0 = {
|
|
6264
|
+
DEFAULT: 150,
|
|
6265
|
+
MIN: 0,
|
|
6266
|
+
MAX: 500,
|
|
6267
|
+
STEP: 1,
|
|
6268
|
+
JUMP: 10
|
|
6269
|
+
};
|
|
6146
6270
|
|
|
6147
6271
|
// Calculate a bunch of statistics for an array of trials
|
|
6148
6272
|
static trials2stats(trials) {
|
|
@@ -6210,7 +6334,7 @@ class DDMMath {
|
|
|
6210
6334
|
}
|
|
6211
6335
|
|
|
6212
6336
|
// Probability of an Error Response
|
|
6213
|
-
static azv2pE(a, z, v, s = DDMMath.s) {
|
|
6337
|
+
static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6214
6338
|
const zPrime = a * z;
|
|
6215
6339
|
const A = Math.exp(-2 * v * a / s ** 2);
|
|
6216
6340
|
const Z = Math.exp(-2 * v * zPrime / s ** 2);
|
|
@@ -6218,13 +6342,13 @@ class DDMMath {
|
|
|
6218
6342
|
}
|
|
6219
6343
|
|
|
6220
6344
|
// Probability of a Correct Response
|
|
6221
|
-
static azv2pC(a, z, v, s = DDMMath.s) {
|
|
6345
|
+
static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6222
6346
|
return DDMMath.azv2pE(a, 1 - z, -v, s);
|
|
6223
6347
|
}
|
|
6224
6348
|
|
|
6225
6349
|
// Mean Overall RT
|
|
6226
6350
|
// Equation 5 (Grasman et al., 2009)
|
|
6227
|
-
static azvt02m(a, z, v, t0, s = DDMMath.s) {
|
|
6351
|
+
static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6228
6352
|
const zPrime = a * z;
|
|
6229
6353
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6230
6354
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6234,7 +6358,7 @@ class DDMMath {
|
|
|
6234
6358
|
|
|
6235
6359
|
// SD Overall RT
|
|
6236
6360
|
// Equation 6 (Grasman et al., 2009)
|
|
6237
|
-
static azv2sd(a, z, v, s = DDMMath.s) {
|
|
6361
|
+
static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6238
6362
|
const zPrime = a * z;
|
|
6239
6363
|
const A = Math.exp(-2 * v * a / s ** 2) - 1;
|
|
6240
6364
|
const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
|
|
@@ -6244,7 +6368,7 @@ class DDMMath {
|
|
|
6244
6368
|
|
|
6245
6369
|
// Mean Error RT
|
|
6246
6370
|
// Equation 13 (Grasman et al., 2009)
|
|
6247
|
-
static azvt02mE(a, z, v, t0, s = DDMMath.s) {
|
|
6371
|
+
static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6248
6372
|
function phi(x, y) {
|
|
6249
6373
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6250
6374
|
}
|
|
@@ -6255,7 +6379,7 @@ class DDMMath {
|
|
|
6255
6379
|
|
|
6256
6380
|
// SD Error RT
|
|
6257
6381
|
// Equation 14 (Grasman et al., 2009)
|
|
6258
|
-
static azv2sdE(a, z, v, s = DDMMath.s) {
|
|
6382
|
+
static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6259
6383
|
function phi(x, y) {
|
|
6260
6384
|
return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
|
|
6261
6385
|
}
|
|
@@ -6265,17 +6389,17 @@ class DDMMath {
|
|
|
6265
6389
|
}
|
|
6266
6390
|
|
|
6267
6391
|
// Mean Correct RT
|
|
6268
|
-
static azvt02mC(a, z, v, t0, s = DDMMath.s) {
|
|
6392
|
+
static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
|
|
6269
6393
|
return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
|
|
6270
6394
|
}
|
|
6271
6395
|
|
|
6272
6396
|
// SD Correct RT
|
|
6273
|
-
static azv2sdC(a, z, v, s = DDMMath.s) {
|
|
6397
|
+
static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6274
6398
|
return DDMMath.azv2sdE(a, 1 - z, -v, s);
|
|
6275
6399
|
}
|
|
6276
6400
|
|
|
6277
6401
|
// Density of Error RT
|
|
6278
|
-
static tazv2gE(t, a, z, v, s = DDMMath.s) {
|
|
6402
|
+
static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6279
6403
|
if (!t) return 0;
|
|
6280
6404
|
const zPrime = a * z;
|
|
6281
6405
|
const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
|
|
@@ -6292,7 +6416,7 @@ class DDMMath {
|
|
|
6292
6416
|
}
|
|
6293
6417
|
|
|
6294
6418
|
// Density of Correct RT
|
|
6295
|
-
static tazv2gC(t, a, z, v, s = DDMMath.s) {
|
|
6419
|
+
static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
|
|
6296
6420
|
return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
|
|
6297
6421
|
}
|
|
6298
6422
|
|
|
@@ -6427,10 +6551,7 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6427
6551
|
this.startTime = undefined; // Start time of current trial
|
|
6428
6552
|
this.rt = undefined; // RT for current trial
|
|
6429
6553
|
|
|
6430
|
-
this.
|
|
6431
|
-
this.errorCount = 0; // Count of Error Trials
|
|
6432
|
-
this.nrCount = 0; // Count of No Response trials
|
|
6433
|
-
|
|
6554
|
+
this.data = {};
|
|
6434
6555
|
this.trials = []; // Record of trials in block
|
|
6435
6556
|
this.alignState();
|
|
6436
6557
|
}
|
|
@@ -6447,11 +6568,10 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6447
6568
|
}
|
|
6448
6569
|
}
|
|
6449
6570
|
get totalPayoff() {
|
|
6450
|
-
return this.correctCount * this.correctPayoff + this.errorCount * this.errorPayoff + this.nrCount * this.nrPayoff;
|
|
6571
|
+
return this.data.correctCount * this.correctPayoff + this.data.errorCount * this.errorPayoff + this.data.nrCount * this.nrPayoff;
|
|
6451
6572
|
}
|
|
6452
6573
|
alignState() {
|
|
6453
|
-
|
|
6454
|
-
Object.assign(this, stats);
|
|
6574
|
+
this.data = DDMMath.trials2stats(this.trials);
|
|
6455
6575
|
}
|
|
6456
6576
|
start(signal, trial) {
|
|
6457
6577
|
this.startTime = Date.now();
|
|
@@ -6466,7 +6586,6 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6466
6586
|
this.state = 'feedback';
|
|
6467
6587
|
if (this.response === undefined) {
|
|
6468
6588
|
this.outcome = 'nr';
|
|
6469
|
-
this.nrCount += 1;
|
|
6470
6589
|
this.rt = undefined;
|
|
6471
6590
|
this.trials.push({
|
|
6472
6591
|
trial: this.trialCount,
|
|
@@ -6491,10 +6610,8 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6491
6610
|
this.response = response;
|
|
6492
6611
|
if (this.signal === this.response) {
|
|
6493
6612
|
this.outcome = 'correct';
|
|
6494
|
-
this.correctCount += 1;
|
|
6495
6613
|
} else if (this.signal !== this.response) {
|
|
6496
6614
|
this.outcome = 'error';
|
|
6497
|
-
this.errorCount += 1;
|
|
6498
6615
|
}
|
|
6499
6616
|
this.trials.push({
|
|
6500
6617
|
trial: this.trialCount,
|
|
@@ -6513,16 +6630,7 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6513
6630
|
response: this.response,
|
|
6514
6631
|
outcome: this.outcome,
|
|
6515
6632
|
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,
|
|
6633
|
+
data: this.data,
|
|
6526
6634
|
totalPayoff: this.totalPayoff
|
|
6527
6635
|
},
|
|
6528
6636
|
bubbles: true
|
|
@@ -6535,9 +6643,6 @@ class AccumulableResponse extends AccumulableElement {
|
|
|
6535
6643
|
this.signal = undefined;
|
|
6536
6644
|
this.response = undefined;
|
|
6537
6645
|
this.outcome = undefined;
|
|
6538
|
-
this.correctCount = 0;
|
|
6539
|
-
this.errorCount = 0;
|
|
6540
|
-
this.nrCount = 0;
|
|
6541
6646
|
this.trials = [];
|
|
6542
6647
|
this.alignState();
|
|
6543
6648
|
}
|
|
@@ -7228,7 +7333,7 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
|
|
|
7228
7333
|
};
|
|
7229
7334
|
}
|
|
7230
7335
|
|
|
7231
|
-
var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

      return base * sum;
    }

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

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

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

  // Internal dependencies

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

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

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

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

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation\n    z = starting point as a proportion of a\n    v = drift rate (per second)\n    t0 = non-decision time (in milliseconds)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = 1;\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","a","z","v","zPrime","A","exp","Z","azv2pC","azvt02m","t0","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":"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"}');
|
|
7336
|
+
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
7337
|
/* eslint-enable */
|
|
7233
7338
|
|
|
7234
7339
|
/*
|
|
@@ -7244,10 +7349,10 @@ class DDMFit extends AccumulableElement {
|
|
|
7244
7349
|
}
|
|
7245
7350
|
constructor() {
|
|
7246
7351
|
super();
|
|
7247
|
-
this.a =
|
|
7248
|
-
this.z =
|
|
7249
|
-
this.v =
|
|
7250
|
-
this.t0 =
|
|
7352
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7353
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7354
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7355
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7251
7356
|
this.observed = {};
|
|
7252
7357
|
this.predicted = {};
|
|
7253
7358
|
this.working = false;
|
|
@@ -7434,15 +7539,71 @@ class DDMParameters extends AccumulableElement {
|
|
|
7434
7539
|
decidables-slider div {
|
|
7435
7540
|
margin-bottom: 0.25rem;
|
|
7436
7541
|
}
|
|
7542
|
+
|
|
7543
|
+
.a {
|
|
7544
|
+
--decidables-slider-background-color: var(---color-a-light);
|
|
7545
|
+
--decidables-slider-color: var(---color-a);
|
|
7546
|
+
}
|
|
7547
|
+
|
|
7548
|
+
.z {
|
|
7549
|
+
--decidables-slider-background-color: var(---color-z-light);
|
|
7550
|
+
--decidables-slider-color: var(---color-z);
|
|
7551
|
+
}
|
|
7552
|
+
|
|
7553
|
+
.v {
|
|
7554
|
+
--decidables-slider-background-color: var(---color-v-light);
|
|
7555
|
+
--decidables-slider-color: var(---color-v);
|
|
7556
|
+
}
|
|
7557
|
+
|
|
7558
|
+
.t0 {
|
|
7559
|
+
--decidables-slider-background-color: var(---color-t0-light);
|
|
7560
|
+
--decidables-slider-color: var(---color-t0);
|
|
7561
|
+
}
|
|
7437
7562
|
`];
|
|
7438
7563
|
}
|
|
7439
7564
|
render() {
|
|
7440
7565
|
return x$1`
|
|
7441
7566
|
<div class="holder">
|
|
7442
|
-
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7443
|
-
|
|
7444
|
-
|
|
7445
|
-
|
|
7567
|
+
${this.a != null ? x$1`<decidables-slider class="a"
|
|
7568
|
+
?disabled=${!this.interactive}
|
|
7569
|
+
scale
|
|
7570
|
+
min=${DDMMath.a.MIN}
|
|
7571
|
+
max=${DDMMath.a.MAX}
|
|
7572
|
+
step=${DDMMath.a.STEP}
|
|
7573
|
+
.value=${+this.a.toFixed(2)}
|
|
7574
|
+
@change=${this.setBoundarySeparation.bind(this)}
|
|
7575
|
+
@input=${this.setBoundarySeparation.bind(this)}
|
|
7576
|
+
><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
|
|
7577
|
+
${this.z != null ? x$1`<decidables-slider class="z"
|
|
7578
|
+
?disabled=${!this.interactive}
|
|
7579
|
+
scale
|
|
7580
|
+
min=${DDMMath.z.MIN}
|
|
7581
|
+
max=${DDMMath.z.MAX}
|
|
7582
|
+
step=${DDMMath.z.STEP}
|
|
7583
|
+
.value=${+this.z.toFixed(2)}
|
|
7584
|
+
@change=${this.setStartingPoint.bind(this)}
|
|
7585
|
+
@input=${this.setStartingPoint.bind(this)}
|
|
7586
|
+
><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
|
|
7587
|
+
${this.v != null ? x$1`<decidables-slider class="v"
|
|
7588
|
+
?disabled=${!this.interactive}
|
|
7589
|
+
scale
|
|
7590
|
+
min=${DDMMath.v.MIN}
|
|
7591
|
+
max=${DDMMath.v.MAX}
|
|
7592
|
+
step=${DDMMath.v.STEP}
|
|
7593
|
+
.value=${+this.v.toFixed(2)}
|
|
7594
|
+
@change=${this.setDriftRate.bind(this)}
|
|
7595
|
+
@input=${this.setDriftRate.bind(this)}
|
|
7596
|
+
><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
|
|
7597
|
+
${this.t0 != null ? x$1`<decidables-slider class="t0"
|
|
7598
|
+
?disabled=${!this.interactive}
|
|
7599
|
+
scale
|
|
7600
|
+
min=${DDMMath.t0.MIN}
|
|
7601
|
+
max=${DDMMath.t0.MAX}
|
|
7602
|
+
step=${DDMMath.t0.STEP}
|
|
7603
|
+
.value=${+this.t0.toFixed(0)}
|
|
7604
|
+
@change=${this.setNondecisionTime.bind(this)}
|
|
7605
|
+
@input=${this.setNondecisionTime.bind(this)}
|
|
7606
|
+
><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
|
|
7446
7607
|
</div>`;
|
|
7447
7608
|
}
|
|
7448
7609
|
}
|
|
@@ -7580,10 +7741,10 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7580
7741
|
this.resample();
|
|
7581
7742
|
this.human = false;
|
|
7582
7743
|
this.trials = 10;
|
|
7583
|
-
this.a =
|
|
7584
|
-
this.z =
|
|
7585
|
-
this.v =
|
|
7586
|
-
this.t0 =
|
|
7744
|
+
this.a = DDMMath.a.DEFAULT;
|
|
7745
|
+
this.z = DDMMath.z.DEFAULT;
|
|
7746
|
+
this.v = DDMMath.v.DEFAULT;
|
|
7747
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
7587
7748
|
|
|
7588
7749
|
// this.s = null;
|
|
7589
7750
|
// this.sz = null;
|
|
@@ -7644,7 +7805,7 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7644
7805
|
while (path.at(-1).e > bounds.lower && path.at(-1).e < bounds.upper) {
|
|
7645
7806
|
path.push({
|
|
7646
7807
|
t: path.at(-1).t + this.precision * 1000,
|
|
7647
|
-
e: path.at(-1).e + drift + DDMMath.s * random()
|
|
7808
|
+
e: path.at(-1).e + drift + DDMMath.s.DEFAULT * random()
|
|
7648
7809
|
});
|
|
7649
7810
|
}
|
|
7650
7811
|
return path;
|
|
@@ -7934,10 +8095,25 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
7934
8095
|
|
|
7935
8096
|
.t0z .point {
|
|
7936
8097
|
fill: var(---color-element-emphasis);
|
|
8098
|
+
stroke-width: 0;
|
|
7937
8099
|
|
|
7938
8100
|
r: 6px;
|
|
7939
8101
|
}
|
|
7940
8102
|
|
|
8103
|
+
/* Make larger targets for touch users */
|
|
8104
|
+
.interactive .touch {
|
|
8105
|
+
stroke: #000000;
|
|
8106
|
+
stroke-dasharray: none;
|
|
8107
|
+
stroke-opacity: 0;
|
|
8108
|
+
}
|
|
8109
|
+
|
|
8110
|
+
@media (pointer: coarse) {
|
|
8111
|
+
.interactive .touch {
|
|
8112
|
+
stroke-linecap: round;
|
|
8113
|
+
stroke-width: 12;
|
|
8114
|
+
}
|
|
8115
|
+
}
|
|
8116
|
+
|
|
7941
8117
|
.measure {
|
|
7942
8118
|
stroke-width: 2;
|
|
7943
8119
|
}
|
|
@@ -8112,9 +8288,9 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8112
8288
|
let t0 = timeScale.invert(event.x);
|
|
8113
8289
|
let z = (evidenceScale.invert(event.y) + this.a / 2) / this.a;
|
|
8114
8290
|
// Clamp t0
|
|
8115
|
-
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 <
|
|
8291
|
+
t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8116
8292
|
// Clamp z
|
|
8117
|
-
z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z <
|
|
8293
|
+
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
8294
|
this.t0 = t0;
|
|
8119
8295
|
this.z = z;
|
|
8120
8296
|
this.alignState();
|
|
@@ -8144,7 +8320,7 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8144
8320
|
this.drag = true;
|
|
8145
8321
|
let v = (evidenceScale.invert(event.y) - this.startingPoint) / (timeScale.invert(event.x) - this.t0) * 1000;
|
|
8146
8322
|
// Clamp drift rate
|
|
8147
|
-
v = v <
|
|
8323
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8148
8324
|
this.v = v;
|
|
8149
8325
|
this.alignState();
|
|
8150
8326
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8168,12 +8344,13 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8168
8344
|
}).on('start', event => {
|
|
8169
8345
|
const element = event.currentTarget;
|
|
8170
8346
|
select(element).classed('dragging', true);
|
|
8171
|
-
}).on('drag',
|
|
8347
|
+
}).on('drag', event => {
|
|
8172
8348
|
this.drag = true;
|
|
8173
|
-
|
|
8174
|
-
|
|
8175
|
-
|
|
8176
|
-
|
|
8349
|
+
const boundary = evidenceScale.invert(event.y);
|
|
8350
|
+
let a = Math.abs(boundary * 2);
|
|
8351
|
+
// Clamp a
|
|
8352
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8353
|
+
this.a = a;
|
|
8177
8354
|
this.alignState();
|
|
8178
8355
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
8179
8356
|
detail: {
|
|
@@ -8614,20 +8791,23 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8614
8791
|
return `boundary ${index === 0 ? 'correct' : 'error'}`;
|
|
8615
8792
|
});
|
|
8616
8793
|
boundaryEnter.append('line').classed('line', true);
|
|
8794
|
+
boundaryEnter.append('line').classed('line touch', true);
|
|
8617
8795
|
// MERGE
|
|
8618
8796
|
const boundaryMerge = boundaryEnter.merge(boundaryUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? (event, datum) => {
|
|
8619
8797
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8620
|
-
let
|
|
8798
|
+
let {
|
|
8799
|
+
a
|
|
8800
|
+
} = this;
|
|
8621
8801
|
switch (event.key) {
|
|
8622
8802
|
case 'ArrowUp':
|
|
8623
|
-
a += datum.bound === 'upper' ? event.shiftKey ?
|
|
8803
|
+
a += datum.bound === 'upper' ? event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP : event.shiftKey ? -0.01 : -0.1;
|
|
8624
8804
|
break;
|
|
8625
8805
|
case 'ArrowDown':
|
|
8626
|
-
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ?
|
|
8806
|
+
a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP;
|
|
8627
8807
|
break;
|
|
8628
8808
|
}
|
|
8629
|
-
// Clamp
|
|
8630
|
-
a = a <
|
|
8809
|
+
// Clamp a
|
|
8810
|
+
a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
|
|
8631
8811
|
this.a = a;
|
|
8632
8812
|
this.alignState();
|
|
8633
8813
|
this.dispatchEvent(new CustomEvent('ddm-model-a', {
|
|
@@ -8651,6 +8831,11 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8651
8831
|
}).attr('y2', datum => {
|
|
8652
8832
|
return evidenceScale(datum.value);
|
|
8653
8833
|
});
|
|
8834
|
+
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 => {
|
|
8835
|
+
return evidenceScale(datum.value);
|
|
8836
|
+
}).attr('y2', datum => {
|
|
8837
|
+
return evidenceScale(datum.value);
|
|
8838
|
+
});
|
|
8654
8839
|
// EXIT
|
|
8655
8840
|
boundaryUpdate.exit().remove();
|
|
8656
8841
|
|
|
@@ -8664,21 +8849,25 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8664
8849
|
// ENTER
|
|
8665
8850
|
const driftEnter = driftUpdate.enter().append('g').classed('drift', true);
|
|
8666
8851
|
driftEnter.append('line').classed('line', true);
|
|
8852
|
+
driftEnter.append('line').classed('line touch', true);
|
|
8667
8853
|
driftEnter.append('path').classed('arrow', true);
|
|
8854
|
+
driftEnter.append('path').classed('arrow touch', true);
|
|
8668
8855
|
// MERGE
|
|
8669
8856
|
const driftMerge = driftEnter.merge(driftUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8670
8857
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8671
|
-
let
|
|
8858
|
+
let {
|
|
8859
|
+
v
|
|
8860
|
+
} = this;
|
|
8672
8861
|
switch (event.key) {
|
|
8673
8862
|
case 'ArrowUp':
|
|
8674
|
-
v += event.shiftKey ?
|
|
8863
|
+
v += event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8675
8864
|
break;
|
|
8676
8865
|
case 'ArrowDown':
|
|
8677
|
-
v -= event.shiftKey ?
|
|
8866
|
+
v -= event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
|
|
8678
8867
|
break;
|
|
8679
8868
|
}
|
|
8680
8869
|
// Clamp z
|
|
8681
|
-
v = v <
|
|
8870
|
+
v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
|
|
8682
8871
|
this.v = v;
|
|
8683
8872
|
this.alignState();
|
|
8684
8873
|
this.dispatchEvent(new CustomEvent('ddm-model-v', {
|
|
@@ -8703,11 +8892,17 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8703
8892
|
rotate(${-Math.atan(datum.v / 1000 * scaleRatio) * (180 / Math.PI)})`;
|
|
8704
8893
|
});
|
|
8705
8894
|
driftMerge.select('.line').attr('x2', timeScale(200));
|
|
8895
|
+
driftMerge.select('.line.touch').attr('x2', timeScale(200));
|
|
8706
8896
|
driftMerge.select('.arrow').attr('d', `
|
|
8707
8897
|
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8708
8898
|
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8709
8899
|
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8710
8900
|
`);
|
|
8901
|
+
driftMerge.select('.arrow.touch').attr('d', `
|
|
8902
|
+
M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
|
|
8903
|
+
l ${this.rem * 0.5},${this.rem * 0.5}
|
|
8904
|
+
l ${-this.rem * 0.5},${this.rem * 0.5}
|
|
8905
|
+
`);
|
|
8711
8906
|
// EXIT
|
|
8712
8907
|
driftUpdate.exit().remove();
|
|
8713
8908
|
|
|
@@ -8720,21 +8915,24 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8720
8915
|
// ENTER
|
|
8721
8916
|
const t0zEnter = t0zUpdate.enter().append('g').classed('t0z', true);
|
|
8722
8917
|
t0zEnter.append('line').classed('line', true);
|
|
8723
|
-
t0zEnter.append('
|
|
8918
|
+
t0zEnter.append('line').classed('line touch', true);
|
|
8919
|
+
t0zEnter.append('circle').classed('point touch', true);
|
|
8724
8920
|
// MERGE
|
|
8725
8921
|
const t0zMerge = t0zEnter.merge(t0zUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
|
|
8726
8922
|
if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
|
|
8727
|
-
let
|
|
8923
|
+
let {
|
|
8924
|
+
z
|
|
8925
|
+
} = this;
|
|
8728
8926
|
switch (event.key) {
|
|
8729
8927
|
case 'ArrowUp':
|
|
8730
|
-
z += event.shiftKey ?
|
|
8928
|
+
z += event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8731
8929
|
break;
|
|
8732
8930
|
case 'ArrowDown':
|
|
8733
|
-
z -= event.shiftKey ?
|
|
8931
|
+
z -= event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
|
|
8734
8932
|
break;
|
|
8735
8933
|
}
|
|
8736
8934
|
// Clamp z
|
|
8737
|
-
z = z <
|
|
8935
|
+
z = z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
|
|
8738
8936
|
this.z = z;
|
|
8739
8937
|
this.alignState();
|
|
8740
8938
|
this.dispatchEvent(new CustomEvent('ddm-model-z', {
|
|
@@ -8749,14 +8947,14 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8749
8947
|
let t0 = this.t0; /* eslint-disable-line prefer-destructuring */
|
|
8750
8948
|
switch (event.key) {
|
|
8751
8949
|
case 'ArrowRight':
|
|
8752
|
-
t0 += event.shiftKey ?
|
|
8950
|
+
t0 += event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8753
8951
|
break;
|
|
8754
8952
|
case 'ArrowLeft':
|
|
8755
|
-
t0 -= event.shiftKey ?
|
|
8953
|
+
t0 -= event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
|
|
8756
8954
|
break;
|
|
8757
8955
|
}
|
|
8758
8956
|
// Clamp t0
|
|
8759
|
-
t0 = t0 <
|
|
8957
|
+
t0 = t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
|
|
8760
8958
|
this.t0 = t0;
|
|
8761
8959
|
this.alignState();
|
|
8762
8960
|
this.dispatchEvent(new CustomEvent('ddm-model-t0', {
|
|
@@ -8782,6 +8980,13 @@ class DDMModel extends DecidablesMixinResizeable(AccumulableElement) {
|
|
|
8782
8980
|
}).attr('y2', datum => {
|
|
8783
8981
|
return evidenceScale(datum.startingPoint);
|
|
8784
8982
|
});
|
|
8983
|
+
t0zMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(0)).attr('x2', datum => {
|
|
8984
|
+
return timeScale(datum.t0);
|
|
8985
|
+
}).attr('y1', datum => {
|
|
8986
|
+
return evidenceScale(datum.startingPoint);
|
|
8987
|
+
}).attr('y2', datum => {
|
|
8988
|
+
return evidenceScale(datum.startingPoint);
|
|
8989
|
+
});
|
|
8785
8990
|
t0zMerge.select('.point').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('cx', datum => {
|
|
8786
8991
|
return timeScale(datum.t0);
|
|
8787
8992
|
}).attr('cy', datum => {
|
|
@@ -9664,9 +9869,9 @@ class DDMEquationAZV2PC extends DDMEquation {
|
|
|
9664
9869
|
}
|
|
9665
9870
|
constructor() {
|
|
9666
9871
|
super();
|
|
9667
|
-
this.a =
|
|
9668
|
-
this.z =
|
|
9669
|
-
this.v =
|
|
9872
|
+
this.a = DDMMath.a.DEFAULT;
|
|
9873
|
+
this.z = DDMMath.z.DEFAULT;
|
|
9874
|
+
this.v = DDMMath.v.DEFAULT;
|
|
9670
9875
|
this.alignState();
|
|
9671
9876
|
}
|
|
9672
9877
|
alignState() {
|
|
@@ -9708,19 +9913,46 @@ class DDMEquationAZV2PC extends DDMEquation {
|
|
|
9708
9913
|
let s;
|
|
9709
9914
|
let accuracy;
|
|
9710
9915
|
if (this.numeric) {
|
|
9711
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
9916
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
9917
|
+
?disabled=${!this.interactive}
|
|
9918
|
+
min=${DDMMath.a.MIN}
|
|
9919
|
+
max=${DDMMath.a.MAX}
|
|
9920
|
+
step=${DDMMath.a.STEP}
|
|
9921
|
+
.value=${this.a}
|
|
9922
|
+
@input=${this.aInput.bind(this)}
|
|
9923
|
+
>
|
|
9712
9924
|
<var class="math-var">a</var>
|
|
9713
9925
|
</decidables-spinner>`;
|
|
9714
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
9926
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
9927
|
+
?disabled=${!this.interactive}
|
|
9928
|
+
min=${DDMMath.z.MIN}
|
|
9929
|
+
max=${DDMMath.z.MAX}
|
|
9930
|
+
step=${DDMMath.z.STEP}
|
|
9931
|
+
.value=${this.z}
|
|
9932
|
+
@input=${this.zInput.bind(this)}
|
|
9933
|
+
>
|
|
9715
9934
|
<var class="math-var">z</var>
|
|
9716
9935
|
</decidables-spinner>`;
|
|
9717
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
9936
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
9937
|
+
?disabled=${!this.interactive}
|
|
9938
|
+
min=${DDMMath.v.MIN}
|
|
9939
|
+
max=${DDMMath.v.MAX}
|
|
9940
|
+
step=${DDMMath.v.STEP}
|
|
9941
|
+
.value=${this.v}
|
|
9942
|
+
@input=${this.vInput.bind(this)}
|
|
9943
|
+
>
|
|
9718
9944
|
<var class="math-var">v</var>
|
|
9719
9945
|
</decidables-spinner>`;
|
|
9720
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
9946
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
9947
|
+
disabled
|
|
9948
|
+
.value=${DDMMath.s.DEFAULT}
|
|
9949
|
+
>
|
|
9721
9950
|
<var class="math-var">s</var>
|
|
9722
9951
|
</decidables-spinner>`;
|
|
9723
|
-
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9952
|
+
accuracy = x$1`<decidables-spinner class="accuracy bottom"
|
|
9953
|
+
disabled
|
|
9954
|
+
.value=${+this.accuracy.toFixed(2)}
|
|
9955
|
+
>
|
|
9724
9956
|
<var>Accuracy</var>
|
|
9725
9957
|
</decidables-spinner>`;
|
|
9726
9958
|
} else {
|
|
@@ -9798,10 +10030,10 @@ class DDMEquationAZVT02M extends DDMEquation {
|
|
|
9798
10030
|
}
|
|
9799
10031
|
constructor() {
|
|
9800
10032
|
super();
|
|
9801
|
-
this.a =
|
|
9802
|
-
this.z =
|
|
9803
|
-
this.v =
|
|
9804
|
-
this.t0 =
|
|
10033
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10034
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10035
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10036
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
9805
10037
|
this.alignState();
|
|
9806
10038
|
}
|
|
9807
10039
|
alignState() {
|
|
@@ -9850,22 +10082,56 @@ class DDMEquationAZVT02M extends DDMEquation {
|
|
|
9850
10082
|
let s;
|
|
9851
10083
|
let meanRT;
|
|
9852
10084
|
if (this.numeric) {
|
|
9853
|
-
a = x$1`<decidables-spinner class="a bottom"
|
|
10085
|
+
a = x$1`<decidables-spinner class="a bottom"
|
|
10086
|
+
?disabled=${!this.interactive}
|
|
10087
|
+
min=${DDMMath.a.MIN}
|
|
10088
|
+
max=${DDMMath.a.MAX}
|
|
10089
|
+
step=${DDMMath.a.STEP}
|
|
10090
|
+
.value=${this.a}
|
|
10091
|
+
@input=${this.aInput.bind(this)}
|
|
10092
|
+
>
|
|
9854
10093
|
<var class="math-var">a</var>
|
|
9855
10094
|
</decidables-spinner>`;
|
|
9856
|
-
z = x$1`<decidables-spinner class="z bottom"
|
|
10095
|
+
z = x$1`<decidables-spinner class="z bottom"
|
|
10096
|
+
?disabled=${!this.interactive}
|
|
10097
|
+
min=${DDMMath.z.MIN}
|
|
10098
|
+
max=${DDMMath.z.MAX}
|
|
10099
|
+
step=${DDMMath.z.STEP}
|
|
10100
|
+
.value=${this.z}
|
|
10101
|
+
@input=${this.zInput.bind(this)}
|
|
10102
|
+
>
|
|
9857
10103
|
<var class="math-var">z</var>
|
|
9858
10104
|
</decidables-spinner>`;
|
|
9859
|
-
v = x$1`<decidables-spinner class="v bottom"
|
|
10105
|
+
v = x$1`<decidables-spinner class="v bottom"
|
|
10106
|
+
?disabled=${!this.interactive}
|
|
10107
|
+
min=${DDMMath.v.MIN}
|
|
10108
|
+
max=${DDMMath.v.MAX}
|
|
10109
|
+
step=${DDMMath.v.STEP}
|
|
10110
|
+
.value=${this.v}
|
|
10111
|
+
@input=${this.vInput.bind(this)}
|
|
10112
|
+
>
|
|
9860
10113
|
<var class="math-var">v</var>
|
|
9861
10114
|
</decidables-spinner>`;
|
|
9862
|
-
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10115
|
+
t0 = x$1`<decidables-spinner class="t0 bottom"
|
|
10116
|
+
?disabled=${!this.interactive}
|
|
10117
|
+
min=${DDMMath.t0.MIN}
|
|
10118
|
+
max=${DDMMath.t0.MAX}
|
|
10119
|
+
step=${DDMMath.t0.STEP}
|
|
10120
|
+
.value=${this.t0}
|
|
10121
|
+
@input=${this.t0Input.bind(this)}
|
|
10122
|
+
>
|
|
9863
10123
|
<var class="math-var">t<sub>0</sub></var>
|
|
9864
10124
|
</decidables-spinner>`;
|
|
9865
|
-
s = x$1`<decidables-spinner class="s bottom"
|
|
10125
|
+
s = x$1`<decidables-spinner class="s bottom"
|
|
10126
|
+
disabled
|
|
10127
|
+
.value=${DDMMath.s.DEFAULT}
|
|
10128
|
+
>
|
|
9866
10129
|
<var class="math-var">s</var>
|
|
9867
10130
|
</decidables-spinner>`;
|
|
9868
|
-
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10131
|
+
meanRT = x$1`<decidables-spinner class="mean-rt bottom"
|
|
10132
|
+
disabled
|
|
10133
|
+
.value=${+this.meanRT.toFixed(0)}
|
|
10134
|
+
>
|
|
9869
10135
|
<var>Mean RT</var>
|
|
9870
10136
|
</decidables-spinner>`;
|
|
9871
10137
|
} else {
|
|
@@ -9988,17 +10254,74 @@ class DDMExample extends AccumulableElement {
|
|
|
9988
10254
|
}
|
|
9989
10255
|
customElements.define('ddm-example', DDMExample);
|
|
9990
10256
|
|
|
9991
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
9992
|
-
|
|
9993
|
-
|
|
9994
10257
|
/*
|
|
9995
10258
|
DDMExampleHuman element
|
|
9996
10259
|
<ddm-example-human>
|
|
9997
10260
|
*/
|
|
9998
10261
|
class DDMExampleHuman extends DDMExample {
|
|
10262
|
+
static get properties() {
|
|
10263
|
+
return {
|
|
10264
|
+
trials: {
|
|
10265
|
+
attribute: 'trials',
|
|
10266
|
+
type: Number,
|
|
10267
|
+
reflect: true
|
|
10268
|
+
},
|
|
10269
|
+
duration: {
|
|
10270
|
+
attribute: 'duration',
|
|
10271
|
+
type: Number,
|
|
10272
|
+
reflect: true
|
|
10273
|
+
},
|
|
10274
|
+
coherence: {
|
|
10275
|
+
attribute: 'coherence',
|
|
10276
|
+
type: Number,
|
|
10277
|
+
reflect: true
|
|
10278
|
+
},
|
|
10279
|
+
color: {
|
|
10280
|
+
attribute: 'color',
|
|
10281
|
+
type: String,
|
|
10282
|
+
reflect: true
|
|
10283
|
+
},
|
|
10284
|
+
a: {
|
|
10285
|
+
attribute: false,
|
|
10286
|
+
type: Number,
|
|
10287
|
+
reflect: false
|
|
10288
|
+
},
|
|
10289
|
+
z: {
|
|
10290
|
+
attribute: false,
|
|
10291
|
+
type: Number,
|
|
10292
|
+
reflect: false
|
|
10293
|
+
},
|
|
10294
|
+
v: {
|
|
10295
|
+
attribute: false,
|
|
10296
|
+
type: Number,
|
|
10297
|
+
reflect: false
|
|
10298
|
+
},
|
|
10299
|
+
t0: {
|
|
10300
|
+
attribute: false,
|
|
10301
|
+
type: Number,
|
|
10302
|
+
reflect: false
|
|
10303
|
+
}
|
|
10304
|
+
};
|
|
10305
|
+
}
|
|
9999
10306
|
constructor() {
|
|
10000
10307
|
super();
|
|
10001
|
-
this.
|
|
10308
|
+
this.trials = 10;
|
|
10309
|
+
this.duration = 2000;
|
|
10310
|
+
this.coherence = 0.5;
|
|
10311
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10312
|
+
this.color = 'outcome';
|
|
10313
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10314
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10315
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10316
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10317
|
+
this.accumulableControl = null;
|
|
10318
|
+
this.rdkTask = null;
|
|
10319
|
+
this.accumulableResponse = null;
|
|
10320
|
+
this.accumulableTable = null;
|
|
10321
|
+
this.ddmParameters = null;
|
|
10322
|
+
this.ddmModel = null;
|
|
10323
|
+
this.ddmFit = null;
|
|
10324
|
+
this.data = undefined;
|
|
10002
10325
|
}
|
|
10003
10326
|
connectedCallback() {
|
|
10004
10327
|
super.connectedCallback();
|
|
@@ -10012,56 +10335,31 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10012
10335
|
|
|
10013
10336
|
// Initialize
|
|
10014
10337
|
this.ddmModel.clear();
|
|
10015
|
-
if (this.accumulableControl
|
|
10338
|
+
if (this.accumulableControl) {
|
|
10016
10339
|
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
|
-
}
|
|
10340
|
+
this.trials = event.detail.trials;
|
|
10023
10341
|
});
|
|
10024
|
-
}
|
|
10025
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('duration')) {
|
|
10026
10342
|
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
|
-
}
|
|
10343
|
+
this.duration = event.detail.duration;
|
|
10032
10344
|
});
|
|
10033
|
-
}
|
|
10034
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('coherence')) {
|
|
10035
10345
|
this.accumulableControl.addEventListener('accumulable-control-coherence', event => {
|
|
10036
|
-
|
|
10037
|
-
this.rdkTask.coherence = event.detail.coherence;
|
|
10038
|
-
}
|
|
10346
|
+
this.coherence = event.detail.coherence;
|
|
10039
10347
|
});
|
|
10040
|
-
}
|
|
10041
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('color')) {
|
|
10042
10348
|
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10043
|
-
|
|
10044
|
-
this.accumulableTable.color = event.detail.color;
|
|
10045
|
-
}
|
|
10349
|
+
this.color = event.detail.color;
|
|
10046
10350
|
});
|
|
10047
|
-
}
|
|
10048
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('run')) {
|
|
10049
10351
|
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10050
10352
|
) => {
|
|
10051
10353
|
if (this.rdkTask) {
|
|
10052
10354
|
this.rdkTask.running = true;
|
|
10053
10355
|
}
|
|
10054
10356
|
});
|
|
10055
|
-
}
|
|
10056
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('pause')) {
|
|
10057
10357
|
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10058
10358
|
) => {
|
|
10059
10359
|
if (this.rdkTask) {
|
|
10060
10360
|
this.rdkTask.running = false;
|
|
10061
10361
|
}
|
|
10062
10362
|
});
|
|
10063
|
-
}
|
|
10064
|
-
if (this.accumulableControl && this.accumulableControl.hasAttribute('reset')) {
|
|
10065
10363
|
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10066
10364
|
) => {
|
|
10067
10365
|
if (this.rdkTask) {
|
|
@@ -10094,11 +10392,6 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10094
10392
|
}
|
|
10095
10393
|
});
|
|
10096
10394
|
}
|
|
10097
|
-
if (this.rdkTask) {
|
|
10098
|
-
if (this.accumulableResponse) {
|
|
10099
|
-
this.accumulableResponse.trialTotal = this.rdkTask.trials;
|
|
10100
|
-
}
|
|
10101
|
-
}
|
|
10102
10395
|
if (this.rdkTask) {
|
|
10103
10396
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
10104
10397
|
if (this.accumulableResponse) {
|
|
@@ -10124,18 +10417,7 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10124
10417
|
}
|
|
10125
10418
|
if (this.accumulableResponse) {
|
|
10126
10419
|
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
|
-
}
|
|
10420
|
+
this.data = event.detail.data;
|
|
10139
10421
|
if (this.ddmModel) {
|
|
10140
10422
|
this.ddmModel.trial({
|
|
10141
10423
|
index: event.detail.trial,
|
|
@@ -10145,34 +10427,73 @@ class DDMExampleHuman extends DDMExample {
|
|
|
10145
10427
|
}
|
|
10146
10428
|
if (this.ddmFit) {
|
|
10147
10429
|
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
|
|
10430
|
+
accuracy: event.detail.data.accuracy,
|
|
10431
|
+
correctMeanRT: event.detail.data.correctMeanRT,
|
|
10432
|
+
errorMeanRT: event.detail.data.errorMeanRT,
|
|
10433
|
+
meanRT: event.detail.data.meanRT,
|
|
10434
|
+
correctSDRT: event.detail.data.correctSDRT,
|
|
10435
|
+
errorSDRT: event.detail.data.errorSDRT,
|
|
10436
|
+
sdRT: event.detail.data.sdRT
|
|
10155
10437
|
});
|
|
10156
10438
|
}
|
|
10439
|
+
this.requestUpdate();
|
|
10157
10440
|
});
|
|
10158
10441
|
}
|
|
10159
10442
|
if (this.ddmFit) {
|
|
10160
10443
|
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
|
-
}
|
|
10444
|
+
this.a = event.detail.a;
|
|
10445
|
+
this.z = 0.5; // event.detail.z;
|
|
10446
|
+
this.v = event.detail.v;
|
|
10447
|
+
this.t0 = event.detail.t0;
|
|
10173
10448
|
});
|
|
10174
10449
|
}
|
|
10175
10450
|
}
|
|
10451
|
+
update(changedProperties) {
|
|
10452
|
+
super.update(changedProperties);
|
|
10453
|
+
if (this.accumulableControl) {
|
|
10454
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10455
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10456
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10457
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10458
|
+
}
|
|
10459
|
+
if (this.rdkTask) {
|
|
10460
|
+
this.rdkTask.trials = this.trials;
|
|
10461
|
+
this.rdkTask.duration = this.duration;
|
|
10462
|
+
this.rdkTask.wait = this.duration;
|
|
10463
|
+
this.rdkTask.iti = this.duration;
|
|
10464
|
+
this.rdkTask.coherence = this.coherence;
|
|
10465
|
+
}
|
|
10466
|
+
if (this.ddmParameters) {
|
|
10467
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10468
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10469
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10470
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10471
|
+
}
|
|
10472
|
+
if (this.ddmModel) {
|
|
10473
|
+
this.ddmModel.a = +this.a;
|
|
10474
|
+
this.ddmModel.z = +this.z;
|
|
10475
|
+
this.ddmModel.v = +this.v;
|
|
10476
|
+
this.ddmModel.t0 = +this.t0;
|
|
10477
|
+
}
|
|
10478
|
+
if (this.accumulableResponse) {
|
|
10479
|
+
this.accumulableResponse.trialTotal = this.trials;
|
|
10480
|
+
}
|
|
10481
|
+
if (this.accumulableTable) {
|
|
10482
|
+
this.accumulableTable.color = this.color;
|
|
10483
|
+
}
|
|
10484
|
+
if (this.accumulableTable && this.data) {
|
|
10485
|
+
this.accumulableTable.correctCount = this.data.correctCount;
|
|
10486
|
+
this.accumulableTable.errorCount = this.data.errorCount;
|
|
10487
|
+
this.accumulableTable.nrCount = this.data.nrCount;
|
|
10488
|
+
this.accumulableTable.accuracy = this.data.accuracy;
|
|
10489
|
+
this.accumulableTable.correctMeanRT = this.data.correctMeanRT;
|
|
10490
|
+
this.accumulableTable.errorMeanRT = this.data.errorMeanRT;
|
|
10491
|
+
this.accumulableTable.meanRT = this.data.meanRT;
|
|
10492
|
+
this.accumulableTable.correctSDRT = this.data.correctSDRT;
|
|
10493
|
+
this.accumulableTable.errorSDRT = this.data.errorSDRT;
|
|
10494
|
+
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10495
|
+
}
|
|
10496
|
+
}
|
|
10176
10497
|
}
|
|
10177
10498
|
customElements.define('ddm-example-human', DDMExampleHuman);
|
|
10178
10499
|
|
|
@@ -10188,6 +10509,11 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10188
10509
|
type: Number,
|
|
10189
10510
|
reflect: true
|
|
10190
10511
|
},
|
|
10512
|
+
color: {
|
|
10513
|
+
attribute: 'color',
|
|
10514
|
+
type: String,
|
|
10515
|
+
reflect: true
|
|
10516
|
+
},
|
|
10191
10517
|
a: {
|
|
10192
10518
|
attribute: 'boundary-separation',
|
|
10193
10519
|
type: Number,
|
|
@@ -10213,10 +10539,12 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10213
10539
|
constructor() {
|
|
10214
10540
|
super();
|
|
10215
10541
|
this.trials = 10;
|
|
10216
|
-
this.
|
|
10217
|
-
this.
|
|
10218
|
-
this.
|
|
10219
|
-
this.
|
|
10542
|
+
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10543
|
+
this.color = 'outcome';
|
|
10544
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10545
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10546
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10547
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10220
10548
|
this.accumulableControl = null;
|
|
10221
10549
|
this.accumulableTable = null;
|
|
10222
10550
|
this.ddmParameters = null;
|
|
@@ -10239,6 +10567,9 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10239
10567
|
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10240
10568
|
this.trials = event.detail.trials;
|
|
10241
10569
|
});
|
|
10570
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10571
|
+
this.color = event.detail.color;
|
|
10572
|
+
});
|
|
10242
10573
|
}
|
|
10243
10574
|
if (this.ddmParameters) {
|
|
10244
10575
|
this.ddmParameters.addEventListener('ddm-parameters-a', event => {
|
|
@@ -10278,7 +10609,11 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10278
10609
|
update(changedProperties) {
|
|
10279
10610
|
super.update(changedProperties);
|
|
10280
10611
|
if (this.accumulableControl) {
|
|
10281
|
-
this.accumulableControl.trials = this.trials;
|
|
10612
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10613
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10614
|
+
}
|
|
10615
|
+
if (this.accumulableTable) {
|
|
10616
|
+
this.accumulableTable.color = this.color;
|
|
10282
10617
|
}
|
|
10283
10618
|
if (this.accumulableTable && this.data) {
|
|
10284
10619
|
this.accumulableTable.correctCount = this.data.correctCount;
|
|
@@ -10293,10 +10628,10 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10293
10628
|
this.accumulableTable.sdRT = this.data.sdRT;
|
|
10294
10629
|
}
|
|
10295
10630
|
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;
|
|
10631
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10632
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10633
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10634
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10300
10635
|
}
|
|
10301
10636
|
if (this.ddmModel) {
|
|
10302
10637
|
this.ddmModel.trials = this.trials;
|
|
@@ -10309,9 +10644,6 @@ class DDMExampleInteractive extends DDMExample {
|
|
|
10309
10644
|
}
|
|
10310
10645
|
customElements.define('ddm-example-interactive', DDMExampleInteractive);
|
|
10311
10646
|
|
|
10312
|
-
// import DDMMath from '@decidables/accumulable-math';
|
|
10313
|
-
|
|
10314
|
-
|
|
10315
10647
|
/*
|
|
10316
10648
|
DDMExampleModel element
|
|
10317
10649
|
<ddm-example-model>
|
|
@@ -10368,10 +10700,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10368
10700
|
this.coherence = 0.5;
|
|
10369
10701
|
this.colors = ['none', 'measure', 'outcome', 'all'];
|
|
10370
10702
|
this.color = 'outcome';
|
|
10371
|
-
this.a =
|
|
10372
|
-
this.z =
|
|
10373
|
-
this.v =
|
|
10374
|
-
this.t0 =
|
|
10703
|
+
this.a = DDMMath.a.DEFAULT;
|
|
10704
|
+
this.z = DDMMath.z.DEFAULT;
|
|
10705
|
+
this.v = DDMMath.v.DEFAULT;
|
|
10706
|
+
this.t0 = DDMMath.t0.DEFAULT;
|
|
10375
10707
|
this.accumulableControl = null;
|
|
10376
10708
|
this.rdkTask = null;
|
|
10377
10709
|
this.ddmParameters = null;
|
|
@@ -10393,60 +10725,48 @@ class DDMExampleModel extends DDMExample {
|
|
|
10393
10725
|
this.accumulableResponse = this.querySelector('accumulable-response');
|
|
10394
10726
|
this.accumulableTable = this.querySelector('accumulable-table');
|
|
10395
10727
|
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
|
-
}
|
|
10728
|
+
this.accumulableControl.addEventListener('accumulable-control-trials', event => {
|
|
10729
|
+
this.trials = event.detail.trials;
|
|
10730
|
+
});
|
|
10731
|
+
this.accumulableControl.addEventListener('accumulable-control-duration', event => {
|
|
10732
|
+
this.duration = event.detail.duration;
|
|
10733
|
+
});
|
|
10734
|
+
this.accumulableControl.addEventListener('accumulable-control-color', event => {
|
|
10735
|
+
this.color = event.detail.color;
|
|
10736
|
+
});
|
|
10737
|
+
this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
|
|
10738
|
+
) => {
|
|
10739
|
+
if (this.rdkTask) {
|
|
10740
|
+
this.rdkTask.running = true;
|
|
10741
|
+
}
|
|
10742
|
+
if (this.ddmModel) {
|
|
10743
|
+
this.ddmModel.resumeTrial();
|
|
10744
|
+
}
|
|
10745
|
+
});
|
|
10746
|
+
this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
|
|
10747
|
+
) => {
|
|
10748
|
+
if (this.rdkTask) {
|
|
10749
|
+
this.rdkTask.running = false;
|
|
10750
|
+
}
|
|
10751
|
+
if (this.ddmModel) {
|
|
10752
|
+
this.ddmModel.pauseTrial();
|
|
10753
|
+
}
|
|
10754
|
+
});
|
|
10755
|
+
this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
|
|
10756
|
+
) => {
|
|
10757
|
+
this.trialCount = 0;
|
|
10758
|
+
this.signal = undefined;
|
|
10759
|
+
if (this.rdkTask) {
|
|
10760
|
+
this.rdkTask.reset();
|
|
10761
|
+
}
|
|
10762
|
+
if (this.ddmModel) {
|
|
10763
|
+
this.ddmModel.trials = this.trialCount;
|
|
10764
|
+
}
|
|
10765
|
+
if (this.accumulableResponse) {
|
|
10766
|
+
this.accumulableResponse.reset();
|
|
10767
|
+
}
|
|
10768
|
+
if (this.accumulableTable) ;
|
|
10769
|
+
});
|
|
10450
10770
|
}
|
|
10451
10771
|
if (this.rdkTask) {
|
|
10452
10772
|
this.rdkTask.addEventListener('rdk-trial-start', event => {
|
|
@@ -10505,17 +10825,15 @@ class DDMExampleModel extends DDMExample {
|
|
|
10505
10825
|
this.model = event.detail.model;
|
|
10506
10826
|
this.requestUpdate();
|
|
10507
10827
|
});
|
|
10508
|
-
|
|
10509
|
-
this.
|
|
10510
|
-
|
|
10511
|
-
|
|
10512
|
-
|
|
10513
|
-
|
|
10514
|
-
|
|
10515
|
-
|
|
10516
|
-
|
|
10517
|
-
});
|
|
10518
|
-
}
|
|
10828
|
+
this.ddmModel.addEventListener('accumulable-response', event => {
|
|
10829
|
+
if (this.accumulableResponse) {
|
|
10830
|
+
const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
|
|
10831
|
+
this.accumulableResponse.responded(response);
|
|
10832
|
+
}
|
|
10833
|
+
this.data = event.detail.data;
|
|
10834
|
+
this.model = event.detail.model;
|
|
10835
|
+
this.requestUpdate();
|
|
10836
|
+
});
|
|
10519
10837
|
}
|
|
10520
10838
|
this.requestUpdate();
|
|
10521
10839
|
}
|
|
@@ -10525,10 +10843,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10525
10843
|
this.trialCount = this.trials;
|
|
10526
10844
|
}
|
|
10527
10845
|
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;
|
|
10846
|
+
this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
|
|
10847
|
+
this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
|
|
10848
|
+
this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
|
|
10849
|
+
this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
|
|
10532
10850
|
}
|
|
10533
10851
|
if (this.rdkTask) {
|
|
10534
10852
|
this.rdkTask.trials = this.trials;
|
|
@@ -10536,10 +10854,10 @@ class DDMExampleModel extends DDMExample {
|
|
|
10536
10854
|
this.rdkTask.coherence = this.coherence;
|
|
10537
10855
|
}
|
|
10538
10856
|
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;
|
|
10857
|
+
this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
|
|
10858
|
+
this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
|
|
10859
|
+
this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
|
|
10860
|
+
this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
|
|
10543
10861
|
}
|
|
10544
10862
|
if (this.ddmModel) {
|
|
10545
10863
|
this.ddmModel.trials = this.trialCount;
|