@decidables/accumulable-elements 0.1.3 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4905,6 +4905,9 @@
4905
4905
  static get styles() {
4906
4906
  return [super.styles, i$3`
4907
4907
  :host {
4908
+ ---decidables-button-background-color-disabled: var(--decidables-button-background-color, var(---color-element-disabled));
4909
+ ---decidables-button-background-color-enabled: var(--decidables-button-background-color, var(---color-element-enabled));
4910
+
4908
4911
  margin: 0.25rem;
4909
4912
  }
4910
4913
 
@@ -4924,7 +4927,7 @@
4924
4927
  }
4925
4928
 
4926
4929
  button:disabled {
4927
- background-color: var(--decidables-button-background-color, var(---color-element-disabled));
4930
+ background-color: var(---decidables-button-background-color-disabled);
4928
4931
  outline: none;
4929
4932
  box-shadow: none;
4930
4933
  }
@@ -4932,7 +4935,7 @@
4932
4935
  button:enabled {
4933
4936
  cursor: pointer;
4934
4937
 
4935
- background-color: var(--decidables-button-background-color, var(---color-element-enabled));
4938
+ background-color: var(---decidables-button-background-color-enabled);
4936
4939
  outline: none;
4937
4940
  box-shadow: var(---shadow-2);
4938
4941
  }
@@ -4983,6 +4986,11 @@
4983
4986
  type: Boolean,
4984
4987
  reflect: true
4985
4988
  },
4989
+ scale: {
4990
+ attribute: 'scale',
4991
+ type: Boolean,
4992
+ reflect: true
4993
+ },
4986
4994
  max: {
4987
4995
  attribute: 'max',
4988
4996
  type: Number,
@@ -5002,6 +5010,11 @@
5002
5010
  attribute: 'value',
5003
5011
  type: Number,
5004
5012
  reflect: true
5013
+ },
5014
+ nonlinear: {
5015
+ attribute: false,
5016
+ type: Boolean,
5017
+ reflect: false
5005
5018
  }
5006
5019
  };
5007
5020
  }
@@ -5010,13 +5023,30 @@
5010
5023
 
5011
5024
  // Attributes
5012
5025
  this.disabled = false;
5026
+ this.scale = false;
5013
5027
  this.max = undefined;
5014
5028
  this.min = undefined;
5015
5029
  this.step = undefined;
5016
5030
  this.value = undefined;
5017
- }
5018
- changed(event) {
5019
- this.value = event.target.value;
5031
+ this.nonlinear = false;
5032
+
5033
+ // Properties
5034
+ this.rangeMax = undefined;
5035
+ this.rangeMin = undefined;
5036
+ this.rangeStep = undefined;
5037
+ this.rangeValue = undefined;
5038
+
5039
+ // Transform
5040
+ this.toRange = undefined;
5041
+ this.fromRange = undefined;
5042
+ }
5043
+ nonlinearRange(nonlinear, toRange, fromRange) {
5044
+ this.nonlinear = nonlinear;
5045
+ this.toRange = nonlinear ? toRange : undefined;
5046
+ this.fromRange = nonlinear ? fromRange : undefined;
5047
+ }
5048
+ rangeChanged(event) {
5049
+ this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
5020
5050
  this.dispatchEvent(new CustomEvent('change', {
5021
5051
  detail: {
5022
5052
  value: this.value
@@ -5024,12 +5054,25 @@
5024
5054
  bubbles: true
5025
5055
  }));
5026
5056
  }
5027
- inputted(event) {
5057
+ rangeInputted(event) {
5058
+ this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
5059
+ }
5060
+ spinnerInputted(event) {
5028
5061
  this.value = event.target.value;
5029
5062
  }
5063
+ willUpdate() {
5064
+ this.rangeMax = this.max === undefined ? undefined : this.nonlinear ? this.toRange(this.max) : this.max;
5065
+ this.rangeMin = this.min === undefined ? undefined : this.nonlinear ? this.toRange(this.min) : this.min;
5066
+ this.rangeStep = this.step === undefined ? undefined : this.nonlinear ? 'any' : this.step;
5067
+ this.rangeValue = this.value === undefined ? undefined : this.nonlinear ? this.toRange(this.value) : this.value;
5068
+ }
5030
5069
  static get styles() {
5031
5070
  return [super.styles, i$3`
5032
5071
  :host {
5072
+ ---decidables-slider-background-color: var(--decidables-slider-background-color, var(---color-element-disabled));
5073
+ ---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
5074
+ ---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
5075
+
5033
5076
  ---shadow-2-rotate: var(--shadow-2-rotate, ${r$3(this.cssBoxShadow(2, true, false))});
5034
5077
  ---shadow-4-rotate: var(--shadow-4-rotate, ${r$3(this.cssBoxShadow(4, true, false))});
5035
5078
  ---shadow-8-rotate: var(--shadow-8-rotate, ${r$3(this.cssBoxShadow(8, true, false))});
@@ -5047,7 +5090,10 @@
5047
5090
  }
5048
5091
 
5049
5092
  .range {
5050
- display: inline-block;
5093
+ position: relative;
5094
+ display: flex;
5095
+
5096
+ flex-direction: row;
5051
5097
 
5052
5098
  width: 3.5rem;
5053
5099
  height: 4.75rem;
@@ -5058,6 +5104,8 @@
5058
5104
  --decidables-spinner-input-width: 3.5rem;
5059
5105
 
5060
5106
  margin: 0 0.25rem 0.25rem;
5107
+
5108
+ background: var(---decidables-spinner-background-color);
5061
5109
  }
5062
5110
 
5063
5111
  /* Adapted from http://danielstern.ca/range.css/#/ */
@@ -5096,14 +5144,14 @@
5096
5144
  width: 100%;
5097
5145
  height: 4px;
5098
5146
 
5099
- background: var(---color-element-disabled);
5147
+ background: var(---decidables-slider-background-color);
5100
5148
  border: 0;
5101
5149
  border-radius: 2px;
5102
5150
  box-shadow: none;
5103
5151
  }
5104
5152
 
5105
5153
  input[type=range]:focus::-webkit-slider-runnable-track {
5106
- background: var(---color-element-disabled);
5154
+ background: var(---decidables-slider-background-color);
5107
5155
  }
5108
5156
 
5109
5157
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
@@ -5111,7 +5159,7 @@
5111
5159
  width: 100%;
5112
5160
  height: 4px;
5113
5161
 
5114
- background: var(---color-element-disabled);
5162
+ background: var(---decidables-slider-background-color);
5115
5163
  border: 0;
5116
5164
  border-radius: 2px;
5117
5165
  box-shadow: none;
@@ -5131,7 +5179,7 @@
5131
5179
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5132
5180
  input[type=range]::-ms-fill-lower {
5133
5181
  background: #cccccc;
5134
- /* background: var(---color-element-disabled); */
5182
+ /* background: var(---decidables-slider-background-color); */
5135
5183
  border: 0;
5136
5184
  border-radius: 2px;
5137
5185
  box-shadow: none;
@@ -5140,7 +5188,7 @@
5140
5188
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5141
5189
  input[type=range]::-ms-fill-upper {
5142
5190
  background: #cccccc;
5143
- /* background: var(---color-element-disabled); */
5191
+ /* background: var(---decidables-slider-background-color); */
5144
5192
  border: 0;
5145
5193
  border-radius: 2px;
5146
5194
  box-shadow: none;
@@ -5148,12 +5196,12 @@
5148
5196
 
5149
5197
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5150
5198
  input[type=range]:focus::-ms-fill-lower {
5151
- background: var(---color-element-disabled);
5199
+ background: var(---decidables-slider-background-color);
5152
5200
  }
5153
5201
 
5154
5202
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5155
5203
  input[type=range]:focus::-ms-fill-upper {
5156
- background: var(---color-element-disabled);
5204
+ background: var(---decidables-slider-background-color);
5157
5205
  }
5158
5206
 
5159
5207
  /* Thumb */
@@ -5171,12 +5219,12 @@
5171
5219
  }
5172
5220
 
5173
5221
  input[type=range]:disabled::-webkit-slider-thumb {
5174
- background: var(---color-element-disabled);
5222
+ background: var(---decidables-slider-background-color);
5175
5223
  box-shadow: none;
5176
5224
  }
5177
5225
 
5178
5226
  input[type=range]:enabled::-webkit-slider-thumb {
5179
- background: var(---color-element-enabled);
5227
+ background: var(---decidables-slider-color);
5180
5228
  box-shadow: var(---shadow-2-rotate);
5181
5229
  }
5182
5230
 
@@ -5207,13 +5255,13 @@
5207
5255
 
5208
5256
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5209
5257
  input[type=range]:disabled::-moz-range-thumb {
5210
- background: var(---color-element-disabled);
5258
+ background: var(---decidables-slider-background-color);
5211
5259
  box-shadow: none;
5212
5260
  }
5213
5261
 
5214
5262
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5215
5263
  input[type=range]:enabled::-moz-range-thumb {
5216
- background: var(---color-element-enabled);
5264
+ background: var(---decidables-slider-color);
5217
5265
  box-shadow: var(---shadow-2-rotate);
5218
5266
  }
5219
5267
 
@@ -5250,13 +5298,13 @@
5250
5298
 
5251
5299
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5252
5300
  input[type=range]:disabled::-ms-thumb {
5253
- background: var(---color-element-disabled);
5301
+ background: var(---decidables-slider-background-color);
5254
5302
  box-shadow: none;
5255
5303
  }
5256
5304
 
5257
5305
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5258
5306
  input[type=range]:enabled::-ms-thumb {
5259
- background: var(---color-element-enabled);
5307
+ background: var(---decidables-slider-color);
5260
5308
  box-shadow: var(---shadow-2-rotate);
5261
5309
  }
5262
5310
 
@@ -5278,6 +5326,33 @@
5278
5326
  :host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {
5279
5327
  box-shadow: var(---shadow-8-rotate);
5280
5328
  }
5329
+
5330
+ datalist {
5331
+ position: absolute;
5332
+ left: 2rem;
5333
+ z-index: -1;
5334
+ display: flex;
5335
+
5336
+ flex-direction: column;
5337
+
5338
+ align-items: flex-start;
5339
+ justify-content: space-between;
5340
+
5341
+ height: 4.75rem;
5342
+
5343
+ font-size: 0.75rem;
5344
+ }
5345
+
5346
+ option {
5347
+ padding: 0;
5348
+
5349
+ line-height: 0.8;
5350
+ min-block-size: 0;
5351
+ }
5352
+
5353
+ option::before {
5354
+ content: "– ";
5355
+ }
5281
5356
  `];
5282
5357
  }
5283
5358
  render() {
@@ -5286,9 +5361,15 @@
5286
5361
  <slot></slot>
5287
5362
  </label>
5288
5363
  <div class="range">
5289
- <input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @change=${this.changed.bind(this)} @input=${this.inputted.bind(this)}>
5364
+ <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)}>
5365
+ ${this.scale ? x$1`
5366
+ <datalist id="ticks">
5367
+ <option value=${o(this.rangeMax)} label=${o(this.max)}></option>
5368
+ <option value=${o(this.rangeMin)} label=${o(this.min)}></option>
5369
+ </datalist>
5370
+ ` : x$1``}
5290
5371
  </div>
5291
- <decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}></decidables-spinner>
5372
+ <decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.spinnerInputted.bind(this)}></decidables-spinner>
5292
5373
  `;
5293
5374
  }
5294
5375
  }
@@ -6089,15 +6170,15 @@
6089
6170
  render() {
6090
6171
  return x$1`
6091
6172
  <div class="holder">
6092
- ${this.trials ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
6173
+ ${this.trials != null ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
6093
6174
  ${this.resample ? x$1`
6094
6175
  <div class="buttons">
6095
6176
  ${this.resample ? x$1`<decidables-button name="resample" @click=${this.doResample.bind(this)}>Resample</decidables-button>` : x$1``}
6096
6177
  </div>
6097
6178
  ` : x$1``}
6098
- ${this.duration ? x$1`<decidables-slider class="duration" min="10" max="2000" step="10" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>` : x$1``}
6099
- ${this.coherence ? x$1`<decidables-slider class="coherence" min="0" max="1" step=".01" .value=${this.coherence} @change=${this.setCoherence.bind(this)} @input=${this.setCoherence.bind(this)}>Coherence</decidables-slider>` : x$1``}
6100
- ${this.color !== undefined ? x$1`
6179
+ ${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``}
6180
+ ${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``}
6181
+ ${this.color != null ? x$1`
6101
6182
  <decidables-toggle class="color" @change=${this.chooseColor.bind(this)}>
6102
6183
  <span slot="label">Emphasis</span>
6103
6184
  <decidables-toggle-option name="toggle" value="none" ?checked=${this.color === 'none'}>None</decidables-toggle-option>
@@ -6122,13 +6203,13 @@
6122
6203
  DDMMath Static Class - Not intended for instantiation!
6123
6204
 
6124
6205
  Model parameters:
6125
- a = boundary separation
6126
- z = starting point as a proportion of a
6127
- v = drift rate (per second)
6128
- t0 = non-decision time (in milliseconds)
6129
- s = within-trial variability in drift rate (s^2 = infinitesimal variance)
6206
+ a = boundary separation [0, Infinity)
6207
+ z = starting point as a proportion of a (0, 1)
6208
+ v = drift rate (per second) (-Infinity, Infinity)
6209
+ t0 = non-decision time (in milliseconds) (0, Infinity)
6210
+ s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)
6130
6211
 
6131
- zPrime = starting point on a 0-to-a scale (typically used in published equations)
6212
+ zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)
6132
6213
 
6133
6214
  Behavioral variables:
6134
6215
  pE = proportion of error trials
@@ -6148,7 +6229,37 @@
6148
6229
  EZ-diffusion model (Wagenmakers et al., 2007)
6149
6230
  */
6150
6231
  class DDMMath {
6151
- static s = 1;
6232
+ static s = {
6233
+ DEFAULT: 1
6234
+ };
6235
+ static a = {
6236
+ DEFAULT: 1.2,
6237
+ MIN: 0.01,
6238
+ MAX: 2.0,
6239
+ STEP: 0.01,
6240
+ JUMP: 0.1
6241
+ };
6242
+ static z = {
6243
+ DEFAULT: 0.55,
6244
+ MIN: 0.01,
6245
+ MAX: 0.99,
6246
+ STEP: 0.01,
6247
+ JUMP: 0.1
6248
+ };
6249
+ static v = {
6250
+ DEFAULT: 1.5,
6251
+ MIN: 0.01,
6252
+ MAX: 5.0,
6253
+ STEP: 0.01,
6254
+ JUMP: 0.1
6255
+ };
6256
+ static t0 = {
6257
+ DEFAULT: 150,
6258
+ MIN: 0,
6259
+ MAX: 500,
6260
+ STEP: 1,
6261
+ JUMP: 10
6262
+ };
6152
6263
 
6153
6264
  // Calculate a bunch of statistics for an array of trials
6154
6265
  static trials2stats(trials) {
@@ -6216,7 +6327,7 @@
6216
6327
  }
6217
6328
 
6218
6329
  // Probability of an Error Response
6219
- static azv2pE(a, z, v, s = DDMMath.s) {
6330
+ static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
6220
6331
  const zPrime = a * z;
6221
6332
  const A = Math.exp(-2 * v * a / s ** 2);
6222
6333
  const Z = Math.exp(-2 * v * zPrime / s ** 2);
@@ -6224,13 +6335,13 @@
6224
6335
  }
6225
6336
 
6226
6337
  // Probability of a Correct Response
6227
- static azv2pC(a, z, v, s = DDMMath.s) {
6338
+ static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
6228
6339
  return DDMMath.azv2pE(a, 1 - z, -v, s);
6229
6340
  }
6230
6341
 
6231
6342
  // Mean Overall RT
6232
6343
  // Equation 5 (Grasman et al., 2009)
6233
- static azvt02m(a, z, v, t0, s = DDMMath.s) {
6344
+ static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6234
6345
  const zPrime = a * z;
6235
6346
  const A = Math.exp(-2 * v * a / s ** 2) - 1;
6236
6347
  const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
@@ -6240,7 +6351,7 @@
6240
6351
 
6241
6352
  // SD Overall RT
6242
6353
  // Equation 6 (Grasman et al., 2009)
6243
- static azv2sd(a, z, v, s = DDMMath.s) {
6354
+ static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
6244
6355
  const zPrime = a * z;
6245
6356
  const A = Math.exp(-2 * v * a / s ** 2) - 1;
6246
6357
  const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
@@ -6250,7 +6361,7 @@
6250
6361
 
6251
6362
  // Mean Error RT
6252
6363
  // Equation 13 (Grasman et al., 2009)
6253
- static azvt02mE(a, z, v, t0, s = DDMMath.s) {
6364
+ static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6254
6365
  function phi(x, y) {
6255
6366
  return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
6256
6367
  }
@@ -6261,7 +6372,7 @@
6261
6372
 
6262
6373
  // SD Error RT
6263
6374
  // Equation 14 (Grasman et al., 2009)
6264
- static azv2sdE(a, z, v, s = DDMMath.s) {
6375
+ static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
6265
6376
  function phi(x, y) {
6266
6377
  return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
6267
6378
  }
@@ -6271,17 +6382,17 @@
6271
6382
  }
6272
6383
 
6273
6384
  // Mean Correct RT
6274
- static azvt02mC(a, z, v, t0, s = DDMMath.s) {
6385
+ static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6275
6386
  return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
6276
6387
  }
6277
6388
 
6278
6389
  // SD Correct RT
6279
- static azv2sdC(a, z, v, s = DDMMath.s) {
6390
+ static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
6280
6391
  return DDMMath.azv2sdE(a, 1 - z, -v, s);
6281
6392
  }
6282
6393
 
6283
6394
  // Density of Error RT
6284
- static tazv2gE(t, a, z, v, s = DDMMath.s) {
6395
+ static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
6285
6396
  if (!t) return 0;
6286
6397
  const zPrime = a * z;
6287
6398
  const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
@@ -6298,7 +6409,7 @@
6298
6409
  }
6299
6410
 
6300
6411
  // Density of Correct RT
6301
- static tazv2gC(t, a, z, v, s = DDMMath.s) {
6412
+ static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
6302
6413
  return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
6303
6414
  }
6304
6415
 
@@ -6433,10 +6544,7 @@
6433
6544
  this.startTime = undefined; // Start time of current trial
6434
6545
  this.rt = undefined; // RT for current trial
6435
6546
 
6436
- this.correctCount = 0; // Count of Correct Trials
6437
- this.errorCount = 0; // Count of Error Trials
6438
- this.nrCount = 0; // Count of No Response trials
6439
-
6547
+ this.data = {};
6440
6548
  this.trials = []; // Record of trials in block
6441
6549
  this.alignState();
6442
6550
  }
@@ -6453,11 +6561,10 @@
6453
6561
  }
6454
6562
  }
6455
6563
  get totalPayoff() {
6456
- return this.correctCount * this.correctPayoff + this.errorCount * this.errorPayoff + this.nrCount * this.nrPayoff;
6564
+ return this.data.correctCount * this.correctPayoff + this.data.errorCount * this.errorPayoff + this.data.nrCount * this.nrPayoff;
6457
6565
  }
6458
6566
  alignState() {
6459
- const stats = DDMMath.trials2stats(this.trials);
6460
- Object.assign(this, stats);
6567
+ this.data = DDMMath.trials2stats(this.trials);
6461
6568
  }
6462
6569
  start(signal, trial) {
6463
6570
  this.startTime = Date.now();
@@ -6472,7 +6579,6 @@
6472
6579
  this.state = 'feedback';
6473
6580
  if (this.response === undefined) {
6474
6581
  this.outcome = 'nr';
6475
- this.nrCount += 1;
6476
6582
  this.rt = undefined;
6477
6583
  this.trials.push({
6478
6584
  trial: this.trialCount,
@@ -6497,10 +6603,8 @@
6497
6603
  this.response = response;
6498
6604
  if (this.signal === this.response) {
6499
6605
  this.outcome = 'correct';
6500
- this.correctCount += 1;
6501
6606
  } else if (this.signal !== this.response) {
6502
6607
  this.outcome = 'error';
6503
- this.errorCount += 1;
6504
6608
  }
6505
6609
  this.trials.push({
6506
6610
  trial: this.trialCount,
@@ -6519,16 +6623,7 @@
6519
6623
  response: this.response,
6520
6624
  outcome: this.outcome,
6521
6625
  payoff: this.trialPayoff,
6522
- correctCount: this.correctCount,
6523
- errorCount: this.errorCount,
6524
- nrCount: this.nrCount,
6525
- accuracy: this.accuracy,
6526
- meanRT: this.meanRT,
6527
- correctMeanRT: this.correctMeanRT,
6528
- errorMeanRT: this.errorMeanRT,
6529
- sdRT: this.sdRT,
6530
- correctSDRT: this.correctSDRT,
6531
- errorSDRT: this.errorSDRT,
6626
+ data: this.data,
6532
6627
  totalPayoff: this.totalPayoff
6533
6628
  },
6534
6629
  bubbles: true
@@ -6541,9 +6636,6 @@
6541
6636
  this.signal = undefined;
6542
6637
  this.response = undefined;
6543
6638
  this.outcome = undefined;
6544
- this.correctCount = 0;
6545
- this.errorCount = 0;
6546
- this.nrCount = 0;
6547
6639
  this.trials = [];
6548
6640
  this.alignState();
6549
6641
  }
@@ -7234,7 +7326,7 @@
7234
7326
  };
7235
7327
  }
7236
7328
 
7237
- var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

      return base * sum;
    }

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

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

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

  // Internal dependencies

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

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

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

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

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

  /*
    DDMMath Static Class - Not intended for instantiation!

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

      return base * sum;
    }

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

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

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

  // Internal dependencies

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

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

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

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

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation [0, Infinity)\n    z = starting point as a proportion of a (0, 1)\n    v = drift rate (per second) (-Infinity, Infinity)\n    t0 = non-decision time (in milliseconds) (0, Infinity)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = {\n    DEFAULT: 1,\n  };\n\n  static a = {\n    DEFAULT: 1.2,\n    MIN: 0.01,\n    MAX: 2.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static z = {\n    DEFAULT: 0.55,\n    MIN: 0.01,\n    MAX: 0.99,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static v = {\n    DEFAULT: 1.5,\n    MIN: 0.01,\n    MAX: 5.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static t0 = {\n    DEFAULT: 150,\n    MIN: 0,\n    MAX: 500,\n    STEP: 1,\n    JUMP: 10,\n  };\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s.DEFAULT});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s.DEFAULT;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","DEFAULT","a","MIN","MAX","STEP","JUMP","z","v","t0","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","zPrime","A","exp","Z","azv2pC","azvt02m","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":"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"}');
7238
7330
  /* eslint-enable */
7239
7331
 
7240
7332
  /*
@@ -7250,10 +7342,10 @@
7250
7342
  }
7251
7343
  constructor() {
7252
7344
  super();
7253
- this.a = 1.2;
7254
- this.z = 0.35;
7255
- this.v = 1.5;
7256
- this.t0 = 150;
7345
+ this.a = DDMMath.a.DEFAULT;
7346
+ this.z = DDMMath.z.DEFAULT;
7347
+ this.v = DDMMath.v.DEFAULT;
7348
+ this.t0 = DDMMath.t0.DEFAULT;
7257
7349
  this.observed = {};
7258
7350
  this.predicted = {};
7259
7351
  this.working = false;
@@ -7440,15 +7532,71 @@
7440
7532
  decidables-slider div {
7441
7533
  margin-bottom: 0.25rem;
7442
7534
  }
7535
+
7536
+ .a {
7537
+ --decidables-slider-background-color: var(---color-a-light);
7538
+ --decidables-slider-color: var(---color-a);
7539
+ }
7540
+
7541
+ .z {
7542
+ --decidables-slider-background-color: var(---color-z-light);
7543
+ --decidables-slider-color: var(---color-z);
7544
+ }
7545
+
7546
+ .v {
7547
+ --decidables-slider-background-color: var(---color-v-light);
7548
+ --decidables-slider-color: var(---color-v);
7549
+ }
7550
+
7551
+ .t0 {
7552
+ --decidables-slider-background-color: var(---color-t0-light);
7553
+ --decidables-slider-color: var(---color-t0);
7554
+ }
7443
7555
  `];
7444
7556
  }
7445
7557
  render() {
7446
7558
  return x$1`
7447
7559
  <div class="holder">
7448
- ${this.a != null ? x$1`<decidables-slider class="a" ?disabled=${!this.interactive} min="0.01" max="2" step="0.01" .value=${+this.a.toFixed(2)} @change=${this.setBoundarySeparation.bind(this)} @input=${this.setBoundarySeparation.bind(this)}><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
7449
- ${this.z != null ? x$1`<decidables-slider class="z" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value=${+this.z.toFixed(2)} @change=${this.setStartingPoint.bind(this)} @input=${this.setStartingPoint.bind(this)}><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
7450
- ${this.v != null ? x$1`<decidables-slider class="v" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value=${+this.v.toFixed(2)} @change=${this.setDriftRate.bind(this)} @input=${this.setDriftRate.bind(this)}><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
7451
- ${this.t0 != null ? x$1`<decidables-slider class="t0" ?disabled=${!this.interactive} min="0" max="500" step="1" .value=${+this.t0.toFixed(0)} @change=${this.setNondecisionTime.bind(this)} @input=${this.setNondecisionTime.bind(this)}><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
7560
+ ${this.a != null ? x$1`<decidables-slider class="a"
7561
+ ?disabled=${!this.interactive}
7562
+ scale
7563
+ min=${DDMMath.a.MIN}
7564
+ max=${DDMMath.a.MAX}
7565
+ step=${DDMMath.a.STEP}
7566
+ .value=${+this.a.toFixed(2)}
7567
+ @change=${this.setBoundarySeparation.bind(this)}
7568
+ @input=${this.setBoundarySeparation.bind(this)}
7569
+ ><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
7570
+ ${this.z != null ? x$1`<decidables-slider class="z"
7571
+ ?disabled=${!this.interactive}
7572
+ scale
7573
+ min=${DDMMath.z.MIN}
7574
+ max=${DDMMath.z.MAX}
7575
+ step=${DDMMath.z.STEP}
7576
+ .value=${+this.z.toFixed(2)}
7577
+ @change=${this.setStartingPoint.bind(this)}
7578
+ @input=${this.setStartingPoint.bind(this)}
7579
+ ><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
7580
+ ${this.v != null ? x$1`<decidables-slider class="v"
7581
+ ?disabled=${!this.interactive}
7582
+ scale
7583
+ min=${DDMMath.v.MIN}
7584
+ max=${DDMMath.v.MAX}
7585
+ step=${DDMMath.v.STEP}
7586
+ .value=${+this.v.toFixed(2)}
7587
+ @change=${this.setDriftRate.bind(this)}
7588
+ @input=${this.setDriftRate.bind(this)}
7589
+ ><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
7590
+ ${this.t0 != null ? x$1`<decidables-slider class="t0"
7591
+ ?disabled=${!this.interactive}
7592
+ scale
7593
+ min=${DDMMath.t0.MIN}
7594
+ max=${DDMMath.t0.MAX}
7595
+ step=${DDMMath.t0.STEP}
7596
+ .value=${+this.t0.toFixed(0)}
7597
+ @change=${this.setNondecisionTime.bind(this)}
7598
+ @input=${this.setNondecisionTime.bind(this)}
7599
+ ><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
7452
7600
  </div>`;
7453
7601
  }
7454
7602
  }
@@ -7586,10 +7734,10 @@
7586
7734
  this.resample();
7587
7735
  this.human = false;
7588
7736
  this.trials = 10;
7589
- this.a = 1.2;
7590
- this.z = 0.35;
7591
- this.v = 1.5;
7592
- this.t0 = 150;
7737
+ this.a = DDMMath.a.DEFAULT;
7738
+ this.z = DDMMath.z.DEFAULT;
7739
+ this.v = DDMMath.v.DEFAULT;
7740
+ this.t0 = DDMMath.t0.DEFAULT;
7593
7741
 
7594
7742
  // this.s = null;
7595
7743
  // this.sz = null;
@@ -7650,7 +7798,7 @@
7650
7798
  while (path.at(-1).e > bounds.lower && path.at(-1).e < bounds.upper) {
7651
7799
  path.push({
7652
7800
  t: path.at(-1).t + this.precision * 1000,
7653
- e: path.at(-1).e + drift + DDMMath.s * random()
7801
+ e: path.at(-1).e + drift + DDMMath.s.DEFAULT * random()
7654
7802
  });
7655
7803
  }
7656
7804
  return path;
@@ -7940,10 +8088,25 @@
7940
8088
 
7941
8089
  .t0z .point {
7942
8090
  fill: var(---color-element-emphasis);
8091
+ stroke-width: 0;
7943
8092
 
7944
8093
  r: 6px;
7945
8094
  }
7946
8095
 
8096
+ /* Make larger targets for touch users */
8097
+ .interactive .touch {
8098
+ stroke: #000000;
8099
+ stroke-dasharray: none;
8100
+ stroke-opacity: 0;
8101
+ }
8102
+
8103
+ @media (pointer: coarse) {
8104
+ .interactive .touch {
8105
+ stroke-linecap: round;
8106
+ stroke-width: 12;
8107
+ }
8108
+ }
8109
+
7947
8110
  .measure {
7948
8111
  stroke-width: 2;
7949
8112
  }
@@ -8118,9 +8281,9 @@
8118
8281
  let t0 = timeScale.invert(event.x);
8119
8282
  let z = (evidenceScale.invert(event.y) + this.a / 2) / this.a;
8120
8283
  // Clamp t0
8121
- t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < 0 ? 0 : t0 > 500 ? 500 : t0;
8284
+ t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
8122
8285
  // Clamp z
8123
- z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z < 0.01 ? 0.01 : z > 0.99 ? 0.99 : z;
8286
+ z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
8124
8287
  this.t0 = t0;
8125
8288
  this.z = z;
8126
8289
  this.alignState();
@@ -8150,7 +8313,7 @@
8150
8313
  this.drag = true;
8151
8314
  let v = (evidenceScale.invert(event.y) - this.startingPoint) / (timeScale.invert(event.x) - this.t0) * 1000;
8152
8315
  // Clamp drift rate
8153
- v = v < 0.01 ? 0.01 : v > 5 ? 5 : v;
8316
+ v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
8154
8317
  this.v = v;
8155
8318
  this.alignState();
8156
8319
  this.dispatchEvent(new CustomEvent('ddm-model-v', {
@@ -8174,12 +8337,13 @@
8174
8337
  }).on('start', event => {
8175
8338
  const element = event.currentTarget;
8176
8339
  select(element).classed('dragging', true);
8177
- }).on('drag', (event, datum) => {
8340
+ }).on('drag', event => {
8178
8341
  this.drag = true;
8179
- let boundary = evidenceScale.invert(event.y);
8180
- // Clamp boundaries to visible evidence
8181
- boundary = boundary < this.scale.evidence.min ? this.scale.evidence.min : boundary > this.scale.evidence.max ? this.scale.evidence.max : datum.bound === 'upper' && boundary < 0.005 ? 0.005 : datum.bound === 'lower' && boundary > -5e-3 ? -5e-3 : boundary;
8182
- this.a = Math.abs(boundary * 2);
8342
+ const boundary = evidenceScale.invert(event.y);
8343
+ let a = Math.abs(boundary * 2);
8344
+ // Clamp a
8345
+ a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
8346
+ this.a = a;
8183
8347
  this.alignState();
8184
8348
  this.dispatchEvent(new CustomEvent('ddm-model-a', {
8185
8349
  detail: {
@@ -8620,20 +8784,23 @@
8620
8784
  return `boundary ${index === 0 ? 'correct' : 'error'}`;
8621
8785
  });
8622
8786
  boundaryEnter.append('line').classed('line', true);
8787
+ boundaryEnter.append('line').classed('line touch', true);
8623
8788
  // MERGE
8624
8789
  const boundaryMerge = boundaryEnter.merge(boundaryUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? (event, datum) => {
8625
8790
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8626
- let a = this.a; /* eslint-disable-line prefer-destructuring */
8791
+ let {
8792
+ a
8793
+ } = this;
8627
8794
  switch (event.key) {
8628
8795
  case 'ArrowUp':
8629
- a += datum.bound === 'upper' ? event.shiftKey ? 0.01 : 0.1 : event.shiftKey ? -0.01 : -0.1;
8796
+ a += datum.bound === 'upper' ? event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP : event.shiftKey ? -0.01 : -0.1;
8630
8797
  break;
8631
8798
  case 'ArrowDown':
8632
- a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? 0.01 : 0.1;
8799
+ a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP;
8633
8800
  break;
8634
8801
  }
8635
- // Clamp boundaries to visible evidence
8636
- a = a < 0.01 ? 0.01 : a > this.scale.evidence.max * 2 ? this.scale.evidence.max * 2 : a;
8802
+ // Clamp a
8803
+ a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
8637
8804
  this.a = a;
8638
8805
  this.alignState();
8639
8806
  this.dispatchEvent(new CustomEvent('ddm-model-a', {
@@ -8657,6 +8824,11 @@
8657
8824
  }).attr('y2', datum => {
8658
8825
  return evidenceScale(datum.value);
8659
8826
  });
8827
+ 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 => {
8828
+ return evidenceScale(datum.value);
8829
+ }).attr('y2', datum => {
8830
+ return evidenceScale(datum.value);
8831
+ });
8660
8832
  // EXIT
8661
8833
  boundaryUpdate.exit().remove();
8662
8834
 
@@ -8670,21 +8842,25 @@
8670
8842
  // ENTER
8671
8843
  const driftEnter = driftUpdate.enter().append('g').classed('drift', true);
8672
8844
  driftEnter.append('line').classed('line', true);
8845
+ driftEnter.append('line').classed('line touch', true);
8673
8846
  driftEnter.append('path').classed('arrow', true);
8847
+ driftEnter.append('path').classed('arrow touch', true);
8674
8848
  // MERGE
8675
8849
  const driftMerge = driftEnter.merge(driftUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
8676
8850
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8677
- let v = this.v; /* eslint-disable-line prefer-destructuring */
8851
+ let {
8852
+ v
8853
+ } = this;
8678
8854
  switch (event.key) {
8679
8855
  case 'ArrowUp':
8680
- v += event.shiftKey ? 0.01 : 0.1;
8856
+ v += event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
8681
8857
  break;
8682
8858
  case 'ArrowDown':
8683
- v -= event.shiftKey ? 0.01 : 0.1;
8859
+ v -= event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
8684
8860
  break;
8685
8861
  }
8686
8862
  // Clamp z
8687
- v = v < 0.01 ? 0.01 : v > 5 ? 5 : v;
8863
+ v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
8688
8864
  this.v = v;
8689
8865
  this.alignState();
8690
8866
  this.dispatchEvent(new CustomEvent('ddm-model-v', {
@@ -8709,11 +8885,17 @@
8709
8885
  rotate(${-Math.atan(datum.v / 1000 * scaleRatio) * (180 / Math.PI)})`;
8710
8886
  });
8711
8887
  driftMerge.select('.line').attr('x2', timeScale(200));
8888
+ driftMerge.select('.line.touch').attr('x2', timeScale(200));
8712
8889
  driftMerge.select('.arrow').attr('d', `
8713
8890
  M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
8714
8891
  l ${this.rem * 0.5},${this.rem * 0.5}
8715
8892
  l ${-this.rem * 0.5},${this.rem * 0.5}
8716
8893
  `);
8894
+ driftMerge.select('.arrow.touch').attr('d', `
8895
+ M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
8896
+ l ${this.rem * 0.5},${this.rem * 0.5}
8897
+ l ${-this.rem * 0.5},${this.rem * 0.5}
8898
+ `);
8717
8899
  // EXIT
8718
8900
  driftUpdate.exit().remove();
8719
8901
 
@@ -8726,21 +8908,24 @@
8726
8908
  // ENTER
8727
8909
  const t0zEnter = t0zUpdate.enter().append('g').classed('t0z', true);
8728
8910
  t0zEnter.append('line').classed('line', true);
8729
- t0zEnter.append('circle').classed('point', true);
8911
+ t0zEnter.append('line').classed('line touch', true);
8912
+ t0zEnter.append('circle').classed('point touch', true);
8730
8913
  // MERGE
8731
8914
  const t0zMerge = t0zEnter.merge(t0zUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
8732
8915
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8733
- let z = this.z; /* eslint-disable-line prefer-destructuring */
8916
+ let {
8917
+ z
8918
+ } = this;
8734
8919
  switch (event.key) {
8735
8920
  case 'ArrowUp':
8736
- z += event.shiftKey ? 0.01 : 0.1;
8921
+ z += event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
8737
8922
  break;
8738
8923
  case 'ArrowDown':
8739
- z -= event.shiftKey ? 0.01 : 0.1;
8924
+ z -= event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
8740
8925
  break;
8741
8926
  }
8742
8927
  // Clamp z
8743
- z = z < 0.01 ? 0.01 : z > 0.99 ? 0.99 : z;
8928
+ z = z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
8744
8929
  this.z = z;
8745
8930
  this.alignState();
8746
8931
  this.dispatchEvent(new CustomEvent('ddm-model-z', {
@@ -8755,14 +8940,14 @@
8755
8940
  let t0 = this.t0; /* eslint-disable-line prefer-destructuring */
8756
8941
  switch (event.key) {
8757
8942
  case 'ArrowRight':
8758
- t0 += event.shiftKey ? 1 : 10;
8943
+ t0 += event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
8759
8944
  break;
8760
8945
  case 'ArrowLeft':
8761
- t0 -= event.shiftKey ? 1 : 10;
8946
+ t0 -= event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
8762
8947
  break;
8763
8948
  }
8764
8949
  // Clamp t0
8765
- t0 = t0 < 0 ? 0 : t0 > 500 ? 500 : t0;
8950
+ t0 = t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
8766
8951
  this.t0 = t0;
8767
8952
  this.alignState();
8768
8953
  this.dispatchEvent(new CustomEvent('ddm-model-t0', {
@@ -8788,6 +8973,13 @@
8788
8973
  }).attr('y2', datum => {
8789
8974
  return evidenceScale(datum.startingPoint);
8790
8975
  });
8976
+ t0zMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(0)).attr('x2', datum => {
8977
+ return timeScale(datum.t0);
8978
+ }).attr('y1', datum => {
8979
+ return evidenceScale(datum.startingPoint);
8980
+ }).attr('y2', datum => {
8981
+ return evidenceScale(datum.startingPoint);
8982
+ });
8791
8983
  t0zMerge.select('.point').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('cx', datum => {
8792
8984
  return timeScale(datum.t0);
8793
8985
  }).attr('cy', datum => {
@@ -9670,9 +9862,9 @@
9670
9862
  }
9671
9863
  constructor() {
9672
9864
  super();
9673
- this.a = 1.5;
9674
- this.z = 0.5;
9675
- this.v = 0.1;
9865
+ this.a = DDMMath.a.DEFAULT;
9866
+ this.z = DDMMath.z.DEFAULT;
9867
+ this.v = DDMMath.v.DEFAULT;
9676
9868
  this.alignState();
9677
9869
  }
9678
9870
  alignState() {
@@ -9714,19 +9906,46 @@
9714
9906
  let s;
9715
9907
  let accuracy;
9716
9908
  if (this.numeric) {
9717
- a = x$1`<decidables-spinner class="a bottom" ?disabled=${!this.interactive} min="0.1" max="2" step="0.01" .value="${this.a}" @input=${this.aInput.bind(this)}>
9909
+ a = x$1`<decidables-spinner class="a bottom"
9910
+ ?disabled=${!this.interactive}
9911
+ min=${DDMMath.a.MIN}
9912
+ max=${DDMMath.a.MAX}
9913
+ step=${DDMMath.a.STEP}
9914
+ .value=${this.a}
9915
+ @input=${this.aInput.bind(this)}
9916
+ >
9718
9917
  <var class="math-var">a</var>
9719
9918
  </decidables-spinner>`;
9720
- z = x$1`<decidables-spinner class="z bottom" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value="${this.z}" @input=${this.zInput.bind(this)}>
9919
+ z = x$1`<decidables-spinner class="z bottom"
9920
+ ?disabled=${!this.interactive}
9921
+ min=${DDMMath.z.MIN}
9922
+ max=${DDMMath.z.MAX}
9923
+ step=${DDMMath.z.STEP}
9924
+ .value=${this.z}
9925
+ @input=${this.zInput.bind(this)}
9926
+ >
9721
9927
  <var class="math-var">z</var>
9722
9928
  </decidables-spinner>`;
9723
- v = x$1`<decidables-spinner class="v bottom" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value="${this.v}" @input=${this.vInput.bind(this)}>
9929
+ v = x$1`<decidables-spinner class="v bottom"
9930
+ ?disabled=${!this.interactive}
9931
+ min=${DDMMath.v.MIN}
9932
+ max=${DDMMath.v.MAX}
9933
+ step=${DDMMath.v.STEP}
9934
+ .value=${this.v}
9935
+ @input=${this.vInput.bind(this)}
9936
+ >
9724
9937
  <var class="math-var">v</var>
9725
9938
  </decidables-spinner>`;
9726
- s = x$1`<decidables-spinner class="s bottom" disabled min="0.01" max="1" step="0.01" .value="${DDMMath.s}">
9939
+ s = x$1`<decidables-spinner class="s bottom"
9940
+ disabled
9941
+ .value=${DDMMath.s.DEFAULT}
9942
+ >
9727
9943
  <var class="math-var">s</var>
9728
9944
  </decidables-spinner>`;
9729
- accuracy = x$1`<decidables-spinner class="accuracy bottom" disabled min="0" max="1" step="0.01" .value="${+this.accuracy.toFixed(2)}">
9945
+ accuracy = x$1`<decidables-spinner class="accuracy bottom"
9946
+ disabled
9947
+ .value=${+this.accuracy.toFixed(2)}
9948
+ >
9730
9949
  <var>Accuracy</var>
9731
9950
  </decidables-spinner>`;
9732
9951
  } else {
@@ -9804,10 +10023,10 @@
9804
10023
  }
9805
10024
  constructor() {
9806
10025
  super();
9807
- this.a = 1.5;
9808
- this.z = 0.5;
9809
- this.v = 0.1;
9810
- this.t0 = 200;
10026
+ this.a = DDMMath.a.DEFAULT;
10027
+ this.z = DDMMath.z.DEFAULT;
10028
+ this.v = DDMMath.v.DEFAULT;
10029
+ this.t0 = DDMMath.t0.DEFAULT;
9811
10030
  this.alignState();
9812
10031
  }
9813
10032
  alignState() {
@@ -9856,22 +10075,56 @@
9856
10075
  let s;
9857
10076
  let meanRT;
9858
10077
  if (this.numeric) {
9859
- a = x$1`<decidables-spinner class="a bottom" ?disabled=${!this.interactive} min="0.1" max="2" step="0.01" .value="${this.a}" @input=${this.aInput.bind(this)}>
10078
+ a = x$1`<decidables-spinner class="a bottom"
10079
+ ?disabled=${!this.interactive}
10080
+ min=${DDMMath.a.MIN}
10081
+ max=${DDMMath.a.MAX}
10082
+ step=${DDMMath.a.STEP}
10083
+ .value=${this.a}
10084
+ @input=${this.aInput.bind(this)}
10085
+ >
9860
10086
  <var class="math-var">a</var>
9861
10087
  </decidables-spinner>`;
9862
- z = x$1`<decidables-spinner class="z bottom" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value="${this.z}" @input=${this.zInput.bind(this)}>
10088
+ z = x$1`<decidables-spinner class="z bottom"
10089
+ ?disabled=${!this.interactive}
10090
+ min=${DDMMath.z.MIN}
10091
+ max=${DDMMath.z.MAX}
10092
+ step=${DDMMath.z.STEP}
10093
+ .value=${this.z}
10094
+ @input=${this.zInput.bind(this)}
10095
+ >
9863
10096
  <var class="math-var">z</var>
9864
10097
  </decidables-spinner>`;
9865
- v = x$1`<decidables-spinner class="v bottom" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value="${this.v}" @input=${this.vInput.bind(this)}>
10098
+ v = x$1`<decidables-spinner class="v bottom"
10099
+ ?disabled=${!this.interactive}
10100
+ min=${DDMMath.v.MIN}
10101
+ max=${DDMMath.v.MAX}
10102
+ step=${DDMMath.v.STEP}
10103
+ .value=${this.v}
10104
+ @input=${this.vInput.bind(this)}
10105
+ >
9866
10106
  <var class="math-var">v</var>
9867
10107
  </decidables-spinner>`;
9868
- t0 = x$1`<decidables-spinner class="t0 bottom" ?disabled=${!this.interactive} min="0" max="500" step="1" .value="${this.t0}" @input=${this.t0Input.bind(this)}>
10108
+ t0 = x$1`<decidables-spinner class="t0 bottom"
10109
+ ?disabled=${!this.interactive}
10110
+ min=${DDMMath.t0.MIN}
10111
+ max=${DDMMath.t0.MAX}
10112
+ step=${DDMMath.t0.STEP}
10113
+ .value=${this.t0}
10114
+ @input=${this.t0Input.bind(this)}
10115
+ >
9869
10116
  <var class="math-var">t<sub>0</sub></var>
9870
10117
  </decidables-spinner>`;
9871
- s = x$1`<decidables-spinner class="s bottom" disabled min="0.01" max="1" step="0.01" .value="${DDMMath.s}">
10118
+ s = x$1`<decidables-spinner class="s bottom"
10119
+ disabled
10120
+ .value=${DDMMath.s.DEFAULT}
10121
+ >
9872
10122
  <var class="math-var">s</var>
9873
10123
  </decidables-spinner>`;
9874
- meanRT = x$1`<decidables-spinner class="mean-rt bottom" disabled min="0" max="1" step="0.01" .value="${+this.meanRT.toFixed(0)}">
10124
+ meanRT = x$1`<decidables-spinner class="mean-rt bottom"
10125
+ disabled
10126
+ .value=${+this.meanRT.toFixed(0)}
10127
+ >
9875
10128
  <var>Mean RT</var>
9876
10129
  </decidables-spinner>`;
9877
10130
  } else {
@@ -9994,17 +10247,74 @@
9994
10247
  }
9995
10248
  customElements.define('ddm-example', DDMExample);
9996
10249
 
9997
- // import DDMMath from '@decidables/accumulable-math';
9998
-
9999
-
10000
10250
  /*
10001
10251
  DDMExampleHuman element
10002
10252
  <ddm-example-human>
10003
10253
  */
10004
10254
  class DDMExampleHuman extends DDMExample {
10255
+ static get properties() {
10256
+ return {
10257
+ trials: {
10258
+ attribute: 'trials',
10259
+ type: Number,
10260
+ reflect: true
10261
+ },
10262
+ duration: {
10263
+ attribute: 'duration',
10264
+ type: Number,
10265
+ reflect: true
10266
+ },
10267
+ coherence: {
10268
+ attribute: 'coherence',
10269
+ type: Number,
10270
+ reflect: true
10271
+ },
10272
+ color: {
10273
+ attribute: 'color',
10274
+ type: String,
10275
+ reflect: true
10276
+ },
10277
+ a: {
10278
+ attribute: false,
10279
+ type: Number,
10280
+ reflect: false
10281
+ },
10282
+ z: {
10283
+ attribute: false,
10284
+ type: Number,
10285
+ reflect: false
10286
+ },
10287
+ v: {
10288
+ attribute: false,
10289
+ type: Number,
10290
+ reflect: false
10291
+ },
10292
+ t0: {
10293
+ attribute: false,
10294
+ type: Number,
10295
+ reflect: false
10296
+ }
10297
+ };
10298
+ }
10005
10299
  constructor() {
10006
10300
  super();
10007
- this.trialCount = 0;
10301
+ this.trials = 10;
10302
+ this.duration = 2000;
10303
+ this.coherence = 0.5;
10304
+ this.colors = ['none', 'measure', 'outcome', 'all'];
10305
+ this.color = 'outcome';
10306
+ this.a = DDMMath.a.DEFAULT;
10307
+ this.z = DDMMath.z.DEFAULT;
10308
+ this.v = DDMMath.v.DEFAULT;
10309
+ this.t0 = DDMMath.t0.DEFAULT;
10310
+ this.accumulableControl = null;
10311
+ this.rdkTask = null;
10312
+ this.accumulableResponse = null;
10313
+ this.accumulableTable = null;
10314
+ this.ddmParameters = null;
10315
+ this.ddmModel = null;
10316
+ this.ddmFit = null;
10317
+ this.data = undefined;
10008
10318
  }
10009
10319
  connectedCallback() {
10010
10320
  super.connectedCallback();
@@ -10018,56 +10328,31 @@
10018
10328
 
10019
10329
  // Initialize
10020
10330
  this.ddmModel.clear();
10021
- if (this.accumulableControl && this.accumulableControl.hasAttribute('trials')) {
10331
+ if (this.accumulableControl) {
10022
10332
  this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10023
- if (this.rdkTask) {
10024
- this.rdkTask.trials = event.detail.trials;
10025
- }
10026
- if (this.accumulableResponse) {
10027
- this.accumulableResponse.trialTotal = event.detail.trials;
10028
- }
10333
+ this.trials = event.detail.trials;
10029
10334
  });
10030
- }
10031
- if (this.accumulableControl && this.accumulableControl.hasAttribute('duration')) {
10032
10335
  this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10033
- if (this.rdkTask) {
10034
- this.rdkTask.duration = event.detail.duration;
10035
- this.rdkTask.wait = event.detail.duration;
10036
- this.rdkTask.iti = event.detail.duration;
10037
- }
10336
+ this.duration = event.detail.duration;
10038
10337
  });
10039
- }
10040
- if (this.accumulableControl && this.accumulableControl.hasAttribute('coherence')) {
10041
10338
  this.accumulableControl.addEventListener('accumulable-control-coherence', event => {
10042
- if (this.rdkTask) {
10043
- this.rdkTask.coherence = event.detail.coherence;
10044
- }
10339
+ this.coherence = event.detail.coherence;
10045
10340
  });
10046
- }
10047
- if (this.accumulableControl && this.accumulableControl.hasAttribute('color')) {
10048
10341
  this.accumulableControl.addEventListener('accumulable-control-color', event => {
10049
- if (this.accumulableTable) {
10050
- this.accumulableTable.color = event.detail.color;
10051
- }
10342
+ this.color = event.detail.color;
10052
10343
  });
10053
- }
10054
- if (this.accumulableControl && this.accumulableControl.hasAttribute('run')) {
10055
10344
  this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
10056
10345
  ) => {
10057
10346
  if (this.rdkTask) {
10058
10347
  this.rdkTask.running = true;
10059
10348
  }
10060
10349
  });
10061
- }
10062
- if (this.accumulableControl && this.accumulableControl.hasAttribute('pause')) {
10063
10350
  this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
10064
10351
  ) => {
10065
10352
  if (this.rdkTask) {
10066
10353
  this.rdkTask.running = false;
10067
10354
  }
10068
10355
  });
10069
- }
10070
- if (this.accumulableControl && this.accumulableControl.hasAttribute('reset')) {
10071
10356
  this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
10072
10357
  ) => {
10073
10358
  if (this.rdkTask) {
@@ -10100,11 +10385,6 @@
10100
10385
  }
10101
10386
  });
10102
10387
  }
10103
- if (this.rdkTask) {
10104
- if (this.accumulableResponse) {
10105
- this.accumulableResponse.trialTotal = this.rdkTask.trials;
10106
- }
10107
- }
10108
10388
  if (this.rdkTask) {
10109
10389
  this.rdkTask.addEventListener('rdk-trial-start', event => {
10110
10390
  if (this.accumulableResponse) {
@@ -10130,18 +10410,7 @@
10130
10410
  }
10131
10411
  if (this.accumulableResponse) {
10132
10412
  this.accumulableResponse.addEventListener('accumulable-response', event => {
10133
- if (this.accumulableTable) {
10134
- this.accumulableTable.correctCount = event.detail.correctCount;
10135
- this.accumulableTable.errorCount = event.detail.errorCount;
10136
- this.accumulableTable.nrCount = event.detail.nrCount;
10137
- this.accumulableTable.accuracy = event.detail.accuracy;
10138
- this.accumulableTable.correctMeanRT = event.detail.correctMeanRT;
10139
- this.accumulableTable.errorMeanRT = event.detail.errorMeanRT;
10140
- this.accumulableTable.meanRT = event.detail.meanRT;
10141
- this.accumulableTable.correctSDRT = event.detail.correctSDRT;
10142
- this.accumulableTable.errorSDRT = event.detail.errorSDRT;
10143
- this.accumulableTable.sdRT = event.detail.sdRT;
10144
- }
10413
+ this.data = event.detail.data;
10145
10414
  if (this.ddmModel) {
10146
10415
  this.ddmModel.trial({
10147
10416
  index: event.detail.trial,
@@ -10151,34 +10420,73 @@
10151
10420
  }
10152
10421
  if (this.ddmFit) {
10153
10422
  this.ddmFit.set({
10154
- accuracy: event.detail.accuracy,
10155
- correctMeanRT: event.detail.correctMeanRT,
10156
- errorMeanRT: event.detail.errorMeanRT,
10157
- meanRT: event.detail.meanRT,
10158
- correctSDRT: event.detail.correctSDRT,
10159
- errorSDRT: event.detail.errorSDRT,
10160
- sdRT: event.detail.sdRT
10423
+ accuracy: event.detail.data.accuracy,
10424
+ correctMeanRT: event.detail.data.correctMeanRT,
10425
+ errorMeanRT: event.detail.data.errorMeanRT,
10426
+ meanRT: event.detail.data.meanRT,
10427
+ correctSDRT: event.detail.data.correctSDRT,
10428
+ errorSDRT: event.detail.data.errorSDRT,
10429
+ sdRT: event.detail.data.sdRT
10161
10430
  });
10162
10431
  }
10432
+ this.requestUpdate();
10163
10433
  });
10164
10434
  }
10165
10435
  if (this.ddmFit) {
10166
10436
  this.ddmFit.addEventListener('ddm-fit-update', event => {
10167
- if (this.ddmParameters) {
10168
- this.ddmParameters.a = event.detail.a;
10169
- this.ddmParameters.z = 0.5; // event.detail.z;
10170
- this.ddmParameters.v = event.detail.v;
10171
- this.ddmParameters.t0 = event.detail.t0;
10172
- }
10173
- if (this.ddmModel) {
10174
- this.ddmModel.a = event.detail.a;
10175
- this.ddmModel.z = 0.5; // event.detail.z;
10176
- this.ddmModel.v = event.detail.v;
10177
- this.ddmModel.t0 = event.detail.t0;
10178
- }
10437
+ this.a = event.detail.a;
10438
+ this.z = 0.5; // event.detail.z;
10439
+ this.v = event.detail.v;
10440
+ this.t0 = event.detail.t0;
10179
10441
  });
10180
10442
  }
10181
10443
  }
10444
+ update(changedProperties) {
10445
+ super.update(changedProperties);
10446
+ if (this.accumulableControl) {
10447
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10448
+ this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
10449
+ this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
10450
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10451
+ }
10452
+ if (this.rdkTask) {
10453
+ this.rdkTask.trials = this.trials;
10454
+ this.rdkTask.duration = this.duration;
10455
+ this.rdkTask.wait = this.duration;
10456
+ this.rdkTask.iti = this.duration;
10457
+ this.rdkTask.coherence = this.coherence;
10458
+ }
10459
+ if (this.ddmParameters) {
10460
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10461
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10462
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10463
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10464
+ }
10465
+ if (this.ddmModel) {
10466
+ this.ddmModel.a = +this.a;
10467
+ this.ddmModel.z = +this.z;
10468
+ this.ddmModel.v = +this.v;
10469
+ this.ddmModel.t0 = +this.t0;
10470
+ }
10471
+ if (this.accumulableResponse) {
10472
+ this.accumulableResponse.trialTotal = this.trials;
10473
+ }
10474
+ if (this.accumulableTable) {
10475
+ this.accumulableTable.color = this.color;
10476
+ }
10477
+ if (this.accumulableTable && this.data) {
10478
+ this.accumulableTable.correctCount = this.data.correctCount;
10479
+ this.accumulableTable.errorCount = this.data.errorCount;
10480
+ this.accumulableTable.nrCount = this.data.nrCount;
10481
+ this.accumulableTable.accuracy = this.data.accuracy;
10482
+ this.accumulableTable.correctMeanRT = this.data.correctMeanRT;
10483
+ this.accumulableTable.errorMeanRT = this.data.errorMeanRT;
10484
+ this.accumulableTable.meanRT = this.data.meanRT;
10485
+ this.accumulableTable.correctSDRT = this.data.correctSDRT;
10486
+ this.accumulableTable.errorSDRT = this.data.errorSDRT;
10487
+ this.accumulableTable.sdRT = this.data.sdRT;
10488
+ }
10489
+ }
10182
10490
  }
10183
10491
  customElements.define('ddm-example-human', DDMExampleHuman);
10184
10492
 
@@ -10194,6 +10502,11 @@
10194
10502
  type: Number,
10195
10503
  reflect: true
10196
10504
  },
10505
+ color: {
10506
+ attribute: 'color',
10507
+ type: String,
10508
+ reflect: true
10509
+ },
10197
10510
  a: {
10198
10511
  attribute: 'boundary-separation',
10199
10512
  type: Number,
@@ -10219,10 +10532,12 @@
10219
10532
  constructor() {
10220
10533
  super();
10221
10534
  this.trials = 10;
10222
- this.a = 1.2;
10223
- this.z = 0.35;
10224
- this.v = 1.5;
10225
- this.t0 = 150;
10535
+ this.colors = ['none', 'measure', 'outcome', 'all'];
10536
+ this.color = 'outcome';
10537
+ this.a = DDMMath.a.DEFAULT;
10538
+ this.z = DDMMath.z.DEFAULT;
10539
+ this.v = DDMMath.v.DEFAULT;
10540
+ this.t0 = DDMMath.t0.DEFAULT;
10226
10541
  this.accumulableControl = null;
10227
10542
  this.accumulableTable = null;
10228
10543
  this.ddmParameters = null;
@@ -10245,6 +10560,9 @@
10245
10560
  this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10246
10561
  this.trials = event.detail.trials;
10247
10562
  });
10563
+ this.accumulableControl.addEventListener('accumulable-control-color', event => {
10564
+ this.color = event.detail.color;
10565
+ });
10248
10566
  }
10249
10567
  if (this.ddmParameters) {
10250
10568
  this.ddmParameters.addEventListener('ddm-parameters-a', event => {
@@ -10284,7 +10602,11 @@
10284
10602
  update(changedProperties) {
10285
10603
  super.update(changedProperties);
10286
10604
  if (this.accumulableControl) {
10287
- this.accumulableControl.trials = this.trials;
10605
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10606
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10607
+ }
10608
+ if (this.accumulableTable) {
10609
+ this.accumulableTable.color = this.color;
10288
10610
  }
10289
10611
  if (this.accumulableTable && this.data) {
10290
10612
  this.accumulableTable.correctCount = this.data.correctCount;
@@ -10299,10 +10621,10 @@
10299
10621
  this.accumulableTable.sdRT = this.data.sdRT;
10300
10622
  }
10301
10623
  if (this.ddmParameters) {
10302
- this.ddmParameters.a = this.a;
10303
- this.ddmParameters.z = this.z;
10304
- this.ddmParameters.v = this.v;
10305
- this.ddmParameters.t0 = this.t0;
10624
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10625
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10626
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10627
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10306
10628
  }
10307
10629
  if (this.ddmModel) {
10308
10630
  this.ddmModel.trials = this.trials;
@@ -10315,9 +10637,6 @@
10315
10637
  }
10316
10638
  customElements.define('ddm-example-interactive', DDMExampleInteractive);
10317
10639
 
10318
- // import DDMMath from '@decidables/accumulable-math';
10319
-
10320
-
10321
10640
  /*
10322
10641
  DDMExampleModel element
10323
10642
  <ddm-example-model>
@@ -10374,10 +10693,10 @@
10374
10693
  this.coherence = 0.5;
10375
10694
  this.colors = ['none', 'measure', 'outcome', 'all'];
10376
10695
  this.color = 'outcome';
10377
- this.a = 1.2;
10378
- this.z = 0.35;
10379
- this.v = 1.5;
10380
- this.t0 = 150;
10696
+ this.a = DDMMath.a.DEFAULT;
10697
+ this.z = DDMMath.z.DEFAULT;
10698
+ this.v = DDMMath.v.DEFAULT;
10699
+ this.t0 = DDMMath.t0.DEFAULT;
10381
10700
  this.accumulableControl = null;
10382
10701
  this.rdkTask = null;
10383
10702
  this.ddmParameters = null;
@@ -10399,60 +10718,48 @@
10399
10718
  this.accumulableResponse = this.querySelector('accumulable-response');
10400
10719
  this.accumulableTable = this.querySelector('accumulable-table');
10401
10720
  if (this.accumulableControl) {
10402
- if (this.accumulableControl.hasAttribute('trials')) {
10403
- this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10404
- this.trials = event.detail.trials;
10405
- });
10406
- }
10407
- if (this.accumulableControl.hasAttribute('duration')) {
10408
- this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10409
- this.duration = event.detail.duration;
10410
- });
10411
- }
10412
- if (this.accumulableControl.hasAttribute('color')) {
10413
- this.accumulableControl.addEventListener('accumulable-control-color', event => {
10414
- this.color = event.detail.color;
10415
- });
10416
- }
10417
- if (this.accumulableControl.hasAttribute('run')) {
10418
- this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
10419
- ) => {
10420
- if (this.rdkTask) {
10421
- this.rdkTask.running = true;
10422
- }
10423
- if (this.ddmModel) {
10424
- this.ddmModel.resumeTrial();
10425
- }
10426
- });
10427
- }
10428
- if (this.accumulableControl.hasAttribute('pause')) {
10429
- this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
10430
- ) => {
10431
- if (this.rdkTask) {
10432
- this.rdkTask.running = false;
10433
- }
10434
- if (this.ddmModel) {
10435
- this.ddmModel.pauseTrial();
10436
- }
10437
- });
10438
- }
10439
- if (this.accumulableControl.hasAttribute('reset')) {
10440
- this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
10441
- ) => {
10442
- this.trialCount = 0;
10443
- this.signal = undefined;
10444
- if (this.rdkTask) {
10445
- this.rdkTask.reset();
10446
- }
10447
- if (this.ddmModel) {
10448
- this.ddmModel.trials = this.trialCount;
10449
- }
10450
- if (this.accumulableResponse) {
10451
- this.accumulableResponse.reset();
10452
- }
10453
- if (this.accumulableTable) ;
10454
- });
10455
- }
10721
+ this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10722
+ this.trials = event.detail.trials;
10723
+ });
10724
+ this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10725
+ this.duration = event.detail.duration;
10726
+ });
10727
+ this.accumulableControl.addEventListener('accumulable-control-color', event => {
10728
+ this.color = event.detail.color;
10729
+ });
10730
+ this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
10731
+ ) => {
10732
+ if (this.rdkTask) {
10733
+ this.rdkTask.running = true;
10734
+ }
10735
+ if (this.ddmModel) {
10736
+ this.ddmModel.resumeTrial();
10737
+ }
10738
+ });
10739
+ this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
10740
+ ) => {
10741
+ if (this.rdkTask) {
10742
+ this.rdkTask.running = false;
10743
+ }
10744
+ if (this.ddmModel) {
10745
+ this.ddmModel.pauseTrial();
10746
+ }
10747
+ });
10748
+ this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
10749
+ ) => {
10750
+ this.trialCount = 0;
10751
+ this.signal = undefined;
10752
+ if (this.rdkTask) {
10753
+ this.rdkTask.reset();
10754
+ }
10755
+ if (this.ddmModel) {
10756
+ this.ddmModel.trials = this.trialCount;
10757
+ }
10758
+ if (this.accumulableResponse) {
10759
+ this.accumulableResponse.reset();
10760
+ }
10761
+ if (this.accumulableTable) ;
10762
+ });
10456
10763
  }
10457
10764
  if (this.rdkTask) {
10458
10765
  this.rdkTask.addEventListener('rdk-trial-start', event => {
@@ -10511,17 +10818,15 @@
10511
10818
  this.model = event.detail.model;
10512
10819
  this.requestUpdate();
10513
10820
  });
10514
- if (this.ddmModel) {
10515
- this.ddmModel.addEventListener('accumulable-response', event => {
10516
- if (this.accumulableResponse) {
10517
- const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
10518
- this.accumulableResponse.responded(response);
10519
- }
10520
- this.data = event.detail.data;
10521
- this.model = event.detail.model;
10522
- this.requestUpdate();
10523
- });
10524
- }
10821
+ this.ddmModel.addEventListener('accumulable-response', event => {
10822
+ if (this.accumulableResponse) {
10823
+ const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
10824
+ this.accumulableResponse.responded(response);
10825
+ }
10826
+ this.data = event.detail.data;
10827
+ this.model = event.detail.model;
10828
+ this.requestUpdate();
10829
+ });
10525
10830
  }
10526
10831
  this.requestUpdate();
10527
10832
  }
@@ -10531,10 +10836,10 @@
10531
10836
  this.trialCount = this.trials;
10532
10837
  }
10533
10838
  if (this.accumulableControl) {
10534
- this.accumulableControl.trials = this.trials;
10535
- this.accumulableControl.duration = this.duration;
10536
- this.accumulableControl.coherence = this.coherence;
10537
- this.accumulableControl.color = this.color;
10839
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10840
+ this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
10841
+ this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
10842
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10538
10843
  }
10539
10844
  if (this.rdkTask) {
10540
10845
  this.rdkTask.trials = this.trials;
@@ -10542,10 +10847,10 @@
10542
10847
  this.rdkTask.coherence = this.coherence;
10543
10848
  }
10544
10849
  if (this.ddmParameters) {
10545
- this.ddmParameters.a = this.a;
10546
- this.ddmParameters.z = this.z;
10547
- this.ddmParameters.v = this.v;
10548
- this.ddmParameters.t0 = this.t0;
10850
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10851
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10852
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10853
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10549
10854
  }
10550
10855
  if (this.ddmModel) {
10551
10856
  this.ddmModel.trials = this.trialCount;