jspsych 6.2.0 → 7.1.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.
Files changed (360) hide show
  1. package/README.md +43 -29
  2. package/css/jspsych.css +39 -39
  3. package/dist/JsPsych.d.ts +112 -0
  4. package/dist/TimelineNode.d.ts +34 -0
  5. package/dist/index.browser.js +3164 -0
  6. package/dist/index.browser.js.map +1 -0
  7. package/dist/index.browser.min.js +2 -0
  8. package/dist/index.browser.min.js.map +1 -0
  9. package/dist/index.cjs +3158 -0
  10. package/dist/index.cjs.map +1 -0
  11. package/dist/index.d.ts +11 -0
  12. package/dist/index.js +3152 -0
  13. package/dist/index.js.map +1 -0
  14. package/dist/migration.d.ts +3 -0
  15. package/dist/modules/data/DataCollection.d.ts +45 -0
  16. package/dist/modules/data/DataColumn.d.ts +15 -0
  17. package/dist/modules/data/index.d.ts +25 -0
  18. package/dist/modules/data/utils.d.ts +3 -0
  19. package/dist/modules/extensions.d.ts +22 -0
  20. package/dist/modules/plugin-api/HardwareAPI.d.ts +15 -0
  21. package/dist/modules/plugin-api/KeyboardListenerAPI.d.ts +34 -0
  22. package/dist/modules/plugin-api/MediaAPI.d.ts +27 -0
  23. package/dist/modules/plugin-api/SimulationAPI.d.ts +41 -0
  24. package/dist/modules/plugin-api/TimeoutAPI.d.ts +5 -0
  25. package/dist/modules/plugin-api/index.d.ts +8 -0
  26. package/dist/modules/plugins.d.ts +129 -0
  27. package/dist/modules/randomization.d.ts +35 -0
  28. package/dist/modules/turk.d.ts +40 -0
  29. package/dist/modules/utils.d.ts +7 -0
  30. package/package.json +32 -15
  31. package/src/JsPsych.ts +884 -0
  32. package/src/TimelineNode.ts +536 -0
  33. package/src/index.ts +71 -0
  34. package/src/migration.ts +37 -0
  35. package/src/modules/data/DataCollection.ts +198 -0
  36. package/src/modules/data/DataColumn.ts +86 -0
  37. package/src/modules/data/index.ts +174 -0
  38. package/src/modules/data/utils.ts +75 -0
  39. package/src/modules/extensions.ts +23 -0
  40. package/src/modules/plugin-api/HardwareAPI.ts +32 -0
  41. package/src/modules/plugin-api/KeyboardListenerAPI.ts +165 -0
  42. package/src/modules/plugin-api/MediaAPI.ts +337 -0
  43. package/src/modules/plugin-api/SimulationAPI.ts +181 -0
  44. package/src/modules/plugin-api/TimeoutAPI.ts +16 -0
  45. package/src/modules/plugin-api/index.ts +28 -0
  46. package/src/modules/plugins.ts +158 -0
  47. package/src/modules/randomization.ts +327 -0
  48. package/src/modules/turk.ts +99 -0
  49. package/src/modules/utils.ts +30 -0
  50. package/.github/workflows/jest.yml +0 -20
  51. package/code-of-conduct.md +0 -56
  52. package/contributors.md +0 -61
  53. package/docs/CNAME +0 -1
  54. package/docs/about/about.md +0 -18
  55. package/docs/about/contributing.md +0 -43
  56. package/docs/about/license.md +0 -25
  57. package/docs/about/support.md +0 -7
  58. package/docs/core_library/jspsych-core.md +0 -661
  59. package/docs/core_library/jspsych-data.md +0 -589
  60. package/docs/core_library/jspsych-pluginAPI.md +0 -510
  61. package/docs/core_library/jspsych-randomization.md +0 -397
  62. package/docs/core_library/jspsych-turk.md +0 -102
  63. package/docs/img/blue.png +0 -0
  64. package/docs/img/folder-setup.png +0 -0
  65. package/docs/img/folder-with-html.png +0 -0
  66. package/docs/img/githubreleases.jpg +0 -0
  67. package/docs/img/jspsych-favicon.png +0 -0
  68. package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
  69. package/docs/img/jspsych-logo.jpg +0 -0
  70. package/docs/img/orange.png +0 -0
  71. package/docs/img/palmer_stim.png +0 -0
  72. package/docs/img/progress_bar.png +0 -0
  73. package/docs/img/visual_search_example.jpg +0 -0
  74. package/docs/index.md +0 -9
  75. package/docs/overview/browser-device-support.md +0 -35
  76. package/docs/overview/callbacks.md +0 -140
  77. package/docs/overview/data.md +0 -281
  78. package/docs/overview/exclude-browser.md +0 -32
  79. package/docs/overview/experiment-options.md +0 -121
  80. package/docs/overview/fullscreen.md +0 -36
  81. package/docs/overview/media-preloading.md +0 -91
  82. package/docs/overview/mturk.md +0 -77
  83. package/docs/overview/progress-bar.md +0 -110
  84. package/docs/overview/record-browser-interactions.md +0 -23
  85. package/docs/overview/running-experiments.md +0 -95
  86. package/docs/overview/timeline.md +0 -387
  87. package/docs/overview/trial.md +0 -142
  88. package/docs/plugins/creating-a-plugin.md +0 -79
  89. package/docs/plugins/jspsych-animation.md +0 -40
  90. package/docs/plugins/jspsych-audio-button-response.md +0 -60
  91. package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
  92. package/docs/plugins/jspsych-audio-slider-response.md +0 -53
  93. package/docs/plugins/jspsych-call-function.md +0 -81
  94. package/docs/plugins/jspsych-canvas-button-response.md +0 -66
  95. package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
  96. package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
  97. package/docs/plugins/jspsych-categorize-animation.md +0 -60
  98. package/docs/plugins/jspsych-categorize-html.md +0 -52
  99. package/docs/plugins/jspsych-categorize-image.md +0 -53
  100. package/docs/plugins/jspsych-cloze.md +0 -45
  101. package/docs/plugins/jspsych-external-html.md +0 -70
  102. package/docs/plugins/jspsych-free-sort.md +0 -55
  103. package/docs/plugins/jspsych-fullscreen.md +0 -57
  104. package/docs/plugins/jspsych-html-button-response.md +0 -42
  105. package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
  106. package/docs/plugins/jspsych-html-slider-response.md +0 -45
  107. package/docs/plugins/jspsych-iat-html.md +0 -64
  108. package/docs/plugins/jspsych-iat-image.md +0 -64
  109. package/docs/plugins/jspsych-image-button-response.md +0 -46
  110. package/docs/plugins/jspsych-image-keyboard-response.md +0 -57
  111. package/docs/plugins/jspsych-image-slider-response.md +0 -52
  112. package/docs/plugins/jspsych-instructions.md +0 -58
  113. package/docs/plugins/jspsych-maxdiff.md +0 -42
  114. package/docs/plugins/jspsych-rdk.md +0 -119
  115. package/docs/plugins/jspsych-reconstruction.md +0 -48
  116. package/docs/plugins/jspsych-resize.md +0 -39
  117. package/docs/plugins/jspsych-same-different-html.md +0 -53
  118. package/docs/plugins/jspsych-same-different-image.md +0 -66
  119. package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -50
  120. package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
  121. package/docs/plugins/jspsych-survey-html-form.md +0 -50
  122. package/docs/plugins/jspsych-survey-likert.md +0 -70
  123. package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
  124. package/docs/plugins/jspsych-survey-multi-select.md +0 -53
  125. package/docs/plugins/jspsych-survey-text.md +0 -63
  126. package/docs/plugins/jspsych-video-button-response.md +0 -52
  127. package/docs/plugins/jspsych-video-keyboard-response.md +0 -48
  128. package/docs/plugins/jspsych-video-slider-response.md +0 -58
  129. package/docs/plugins/jspsych-visual-search-circle.md +0 -52
  130. package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
  131. package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
  132. package/docs/plugins/overview.md +0 -111
  133. package/docs/tutorials/hello-world.md +0 -144
  134. package/docs/tutorials/rt-task.md +0 -1107
  135. package/examples/add-to-end-of-timeline.html +0 -32
  136. package/examples/conditional-and-loop-functions.html +0 -63
  137. package/examples/css/jquery-ui.css +0 -1225
  138. package/examples/data-add-properties.html +0 -40
  139. package/examples/data-as-function.html +0 -36
  140. package/examples/data-from-timeline.html +0 -45
  141. package/examples/data-from-url.html +0 -21
  142. package/examples/demo-flanker.html +0 -108
  143. package/examples/demo-simple-rt-task.html +0 -104
  144. package/examples/demos/demo_1.html +0 -29
  145. package/examples/demos/demo_2.html +0 -43
  146. package/examples/demos/demo_3.html +0 -58
  147. package/examples/display-element-to-embed-experiment.html +0 -73
  148. package/examples/end-active-node.html +0 -52
  149. package/examples/end-experiment.html +0 -43
  150. package/examples/exclusions.html +0 -32
  151. package/examples/external_html/simple_consent.html +0 -4
  152. package/examples/img/1.gif +0 -0
  153. package/examples/img/10.gif +0 -0
  154. package/examples/img/11.gif +0 -0
  155. package/examples/img/12.gif +0 -0
  156. package/examples/img/2.gif +0 -0
  157. package/examples/img/3.gif +0 -0
  158. package/examples/img/4.gif +0 -0
  159. package/examples/img/5.gif +0 -0
  160. package/examples/img/6.gif +0 -0
  161. package/examples/img/7.gif +0 -0
  162. package/examples/img/8.gif +0 -0
  163. package/examples/img/9.gif +0 -0
  164. package/examples/img/age/of1.jpg +0 -0
  165. package/examples/img/age/of2.jpg +0 -0
  166. package/examples/img/age/of3.jpg +0 -0
  167. package/examples/img/age/om1.jpg +0 -0
  168. package/examples/img/age/om2.jpg +0 -0
  169. package/examples/img/age/om3.jpg +0 -0
  170. package/examples/img/age/yf1.jpg +0 -0
  171. package/examples/img/age/yf4.jpg +0 -0
  172. package/examples/img/age/yf5.jpg +0 -0
  173. package/examples/img/age/ym2.jpg +0 -0
  174. package/examples/img/age/ym3.jpg +0 -0
  175. package/examples/img/age/ym5.jpg +0 -0
  176. package/examples/img/backwardN.gif +0 -0
  177. package/examples/img/blue.png +0 -0
  178. package/examples/img/con1.png +0 -0
  179. package/examples/img/con2.png +0 -0
  180. package/examples/img/fixation.gif +0 -0
  181. package/examples/img/happy_face_1.jpg +0 -0
  182. package/examples/img/happy_face_2.jpg +0 -0
  183. package/examples/img/happy_face_3.jpg +0 -0
  184. package/examples/img/happy_face_4.jpg +0 -0
  185. package/examples/img/inc1.png +0 -0
  186. package/examples/img/inc2.png +0 -0
  187. package/examples/img/normalN.gif +0 -0
  188. package/examples/img/orange.png +0 -0
  189. package/examples/img/redX.png +0 -0
  190. package/examples/img/ribbon.jpg +0 -0
  191. package/examples/img/sad_face_1.jpg +0 -0
  192. package/examples/img/sad_face_2.jpg +0 -0
  193. package/examples/img/sad_face_3.jpg +0 -0
  194. package/examples/img/sad_face_4.jpg +0 -0
  195. package/examples/js/snap.svg-min.js +0 -21
  196. package/examples/jspsych-RDK.html +0 -58
  197. package/examples/jspsych-animation.html +0 -33
  198. package/examples/jspsych-audio-button-response.html +0 -52
  199. package/examples/jspsych-audio-keyboard-response.html +0 -62
  200. package/examples/jspsych-audio-slider-response.html +0 -55
  201. package/examples/jspsych-call-function.html +0 -32
  202. package/examples/jspsych-canvas-button-response.html +0 -95
  203. package/examples/jspsych-canvas-keyboard-response.html +0 -78
  204. package/examples/jspsych-canvas-slider-response.html +0 -67
  205. package/examples/jspsych-categorize-animation.html +0 -46
  206. package/examples/jspsych-categorize-html.html +0 -38
  207. package/examples/jspsych-categorize-image.html +0 -38
  208. package/examples/jspsych-cloze.html +0 -42
  209. package/examples/jspsych-free-sort.html +0 -97
  210. package/examples/jspsych-fullscreen.html +0 -44
  211. package/examples/jspsych-html-button-response.html +0 -46
  212. package/examples/jspsych-html-keyboard-response.html +0 -42
  213. package/examples/jspsych-html-slider-response.html +0 -53
  214. package/examples/jspsych-iat.html +0 -510
  215. package/examples/jspsych-image-button-response.html +0 -84
  216. package/examples/jspsych-image-keyboard-response.html +0 -78
  217. package/examples/jspsych-image-slider-response.html +0 -76
  218. package/examples/jspsych-instructions.html +0 -37
  219. package/examples/jspsych-maxdiff.html +0 -33
  220. package/examples/jspsych-reconstruction.html +0 -43
  221. package/examples/jspsych-resize.html +0 -34
  222. package/examples/jspsych-same-different-html.html +0 -28
  223. package/examples/jspsych-same-different-image.html +0 -33
  224. package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
  225. package/examples/jspsych-serial-reaction-time.html +0 -54
  226. package/examples/jspsych-survey-html-form.html +0 -33
  227. package/examples/jspsych-survey-likert.html +0 -42
  228. package/examples/jspsych-survey-multi-choice.html +0 -40
  229. package/examples/jspsych-survey-multi-select.html +0 -42
  230. package/examples/jspsych-survey-text.html +0 -34
  231. package/examples/jspsych-video-button-response.html +0 -57
  232. package/examples/jspsych-video-keyboard-response.html +0 -53
  233. package/examples/jspsych-video-slider-response.html +0 -55
  234. package/examples/jspsych-visual-search-circle.html +0 -58
  235. package/examples/jspsych-vsl-animate-occlusion.html +0 -29
  236. package/examples/jspsych-vsl-grid-scene.html +0 -41
  237. package/examples/lexical-decision.html +0 -132
  238. package/examples/manual-preloading.html +0 -53
  239. package/examples/pause-unpause.html +0 -33
  240. package/examples/progress-bar.html +0 -62
  241. package/examples/sound/hammer.mp3 +0 -0
  242. package/examples/sound/sound.mp3 +0 -0
  243. package/examples/sound/speech_blue.mp3 +0 -0
  244. package/examples/sound/speech_green.mp3 +0 -0
  245. package/examples/sound/speech_joke.mp3 +0 -0
  246. package/examples/sound/speech_red.mp3 +0 -0
  247. package/examples/sound/tone.mp3 +0 -0
  248. package/examples/timeline-variables-sampling.html +0 -50
  249. package/examples/timeline-variables.html +0 -55
  250. package/examples/video/sample_video.mp4 +0 -0
  251. package/jspsych.js +0 -2796
  252. package/license.txt +0 -21
  253. package/mkdocs.yml +0 -104
  254. package/plugins/jspsych-animation.js +0 -189
  255. package/plugins/jspsych-audio-button-response.js +0 -247
  256. package/plugins/jspsych-audio-keyboard-response.js +0 -204
  257. package/plugins/jspsych-audio-slider-response.js +0 -262
  258. package/plugins/jspsych-call-function.js +0 -58
  259. package/plugins/jspsych-canvas-button-response.js +0 -199
  260. package/plugins/jspsych-canvas-keyboard-response.js +0 -155
  261. package/plugins/jspsych-canvas-slider-response.js +0 -207
  262. package/plugins/jspsych-categorize-animation.js +0 -266
  263. package/plugins/jspsych-categorize-html.js +0 -220
  264. package/plugins/jspsych-categorize-image.js +0 -222
  265. package/plugins/jspsych-cloze.js +0 -112
  266. package/plugins/jspsych-external-html.js +0 -112
  267. package/plugins/jspsych-free-sort.js +0 -444
  268. package/plugins/jspsych-fullscreen.js +0 -104
  269. package/plugins/jspsych-html-button-response.js +0 -188
  270. package/plugins/jspsych-html-keyboard-response.js +0 -149
  271. package/plugins/jspsych-html-slider-response.js +0 -202
  272. package/plugins/jspsych-iat-html.js +0 -284
  273. package/plugins/jspsych-iat-image.js +0 -286
  274. package/plugins/jspsych-image-button-response.js +0 -311
  275. package/plugins/jspsych-image-keyboard-response.js +0 -247
  276. package/plugins/jspsych-image-slider-response.js +0 -353
  277. package/plugins/jspsych-instructions.js +0 -237
  278. package/plugins/jspsych-maxdiff.js +0 -174
  279. package/plugins/jspsych-rdk.js +0 -1373
  280. package/plugins/jspsych-reconstruction.js +0 -134
  281. package/plugins/jspsych-resize.js +0 -166
  282. package/plugins/jspsych-same-different-html.js +0 -168
  283. package/plugins/jspsych-same-different-image.js +0 -169
  284. package/plugins/jspsych-serial-reaction-time-mouse.js +0 -213
  285. package/plugins/jspsych-serial-reaction-time.js +0 -247
  286. package/plugins/jspsych-survey-html-form.js +0 -171
  287. package/plugins/jspsych-survey-likert.js +0 -195
  288. package/plugins/jspsych-survey-multi-choice.js +0 -208
  289. package/plugins/jspsych-survey-multi-select.js +0 -232
  290. package/plugins/jspsych-survey-text.js +0 -185
  291. package/plugins/jspsych-video-button-response.js +0 -320
  292. package/plugins/jspsych-video-keyboard-response.js +0 -279
  293. package/plugins/jspsych-video-slider-response.js +0 -351
  294. package/plugins/jspsych-visual-search-circle.js +0 -259
  295. package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
  296. package/plugins/jspsych-vsl-grid-scene.js +0 -103
  297. package/plugins/template/jspsych-plugin-template.js +0 -35
  298. package/tests/README.md +0 -7
  299. package/tests/jsPsych/default-iti.test.js +0 -51
  300. package/tests/jsPsych/default-parameters.test.js +0 -58
  301. package/tests/jsPsych/endexperiment.test.js +0 -49
  302. package/tests/jsPsych/events.test.js +0 -369
  303. package/tests/jsPsych/init.test.js +0 -48
  304. package/tests/jsPsych/loads.test.js +0 -7
  305. package/tests/jsPsych/min-rt.test.js +0 -58
  306. package/tests/jsPsych/progressbar.test.js +0 -202
  307. package/tests/jsPsych/timeline-variables.test.js +0 -254
  308. package/tests/jsPsych/timelines.test.js +0 -498
  309. package/tests/jsPsych.data/datacollection.test.js +0 -116
  310. package/tests/jsPsych.data/datacolumn.test.js +0 -50
  311. package/tests/jsPsych.data/datamodule.test.js +0 -152
  312. package/tests/jsPsych.data/dataparameter.test.js +0 -251
  313. package/tests/jsPsych.data/interactions.test.js +0 -109
  314. package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -144
  315. package/tests/jsPsych.randomization/randomziation.test.js +0 -27
  316. package/tests/jsPsych.utils/utils.test.js +0 -58
  317. package/tests/media/blue.png +0 -0
  318. package/tests/media/orange.png +0 -0
  319. package/tests/media/sample_video.mp4 +0 -0
  320. package/tests/media/sound.mp3 +0 -0
  321. package/tests/plugins/plugin-animation.test.js +0 -35
  322. package/tests/plugins/plugin-audio-button-response.test.js +0 -15
  323. package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
  324. package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
  325. package/tests/plugins/plugin-call-function.test.js +0 -49
  326. package/tests/plugins/plugin-categorize-animation.test.js +0 -274
  327. package/tests/plugins/plugin-categorize-html.test.js +0 -17
  328. package/tests/plugins/plugin-categorize-image.test.js +0 -17
  329. package/tests/plugins/plugin-cloze.test.js +0 -140
  330. package/tests/plugins/plugin-free-sort.test.js +0 -112
  331. package/tests/plugins/plugin-fullscreen.test.js +0 -41
  332. package/tests/plugins/plugin-html-button-response.test.js +0 -161
  333. package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
  334. package/tests/plugins/plugin-html-slider-response.test.js +0 -155
  335. package/tests/plugins/plugin-iat-html.test.js +0 -328
  336. package/tests/plugins/plugin-iat-image.test.js +0 -308
  337. package/tests/plugins/plugin-image-button-response.test.js +0 -183
  338. package/tests/plugins/plugin-image-keyboard-response.test.js +0 -154
  339. package/tests/plugins/plugin-image-slider-response.test.js +0 -183
  340. package/tests/plugins/plugin-instructions.test.js +0 -66
  341. package/tests/plugins/plugin-maxdiff.test.js +0 -39
  342. package/tests/plugins/plugin-rdk.test.js +0 -17
  343. package/tests/plugins/plugin-reconstruction.test.js +0 -16
  344. package/tests/plugins/plugin-resize.test.js +0 -16
  345. package/tests/plugins/plugin-same-different-html.test.js +0 -17
  346. package/tests/plugins/plugin-same-different-image.test.js +0 -17
  347. package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
  348. package/tests/plugins/plugin-serial-reaction-time.test.js +0 -69
  349. package/tests/plugins/plugin-survey-html-form.test.js +0 -44
  350. package/tests/plugins/plugin-survey-likert.test.js +0 -48
  351. package/tests/plugins/plugin-survey-multi-choice.test.js +0 -48
  352. package/tests/plugins/plugin-survey-multi-select.test.js +0 -72
  353. package/tests/plugins/plugin-survey-text.test.js +0 -115
  354. package/tests/plugins/plugin-video-button-response.test.js +0 -35
  355. package/tests/plugins/plugin-video-keyboard-response.test.js +0 -35
  356. package/tests/plugins/plugin-video-slider-response.test.js +0 -34
  357. package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
  358. package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
  359. package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
  360. package/tests/testing-utils.js +0 -13
@@ -1,397 +0,0 @@
1
- # jsPsych.randomization
2
-
3
- The jsPsych.randomization module contains methods that are useful for generating random lists of trial variables.
4
-
5
- ---
6
-
7
- ## jsPsych.randomization.factorial
8
-
9
- ```
10
- jsPsych.randomization.factorial(factors, repetitions, unpack)
11
- ```
12
-
13
- ### Parameters
14
-
15
- Parameter | Type | Description
16
- ----------|------|------------
17
- factors | object | The `factors` object should contain a property for each different factor. Each property-factor should have a value of an array, with each element of the array corresponding to a level of the factor.
18
- repetitions | integer | The number of times to repeat each unique combination of the factors in the output sample.
19
- unpack | boolean | If `true` then the output will be an object with a property for each factor in the original `factors` object. The value of each property-factor will be an array containing the levels of the factor in a random order. The order will be consistent across each property-factor (e.g., the first element of each property-factor will specify one unique combination of the factors). If `false`, then the return value will be an array of objects where each property-factor contains only a single value.
20
-
21
- ### Return value
22
-
23
- The return value depends on the `unpack` parameter. See description of the parameter above, and examples below.
24
-
25
- ### Description
26
-
27
- This method takes a list of factors and their levels, and creates a full factorial design by creating each unique combination of the factors. The returned set of combinations is in a random order.
28
-
29
- ### Examples
30
-
31
- #### Create full factorial design
32
- ```javascript
33
- var factors = {
34
- stimulus: ['a.jpg', 'b.jpg'],
35
- ms_delay: [100, 200]
36
- }
37
-
38
- var full_design = jsPsych.randomization.factorial(factors, 1);
39
-
40
- /*
41
- output:
42
- full_design = [
43
- {stimulus: 'a.jpg', ms_delay: 200},
44
- {stimulus: 'b.jpg', ms_delay: 200},
45
- {stimulus: 'b.jpg', ms_delay: 100},
46
- {stimulus: 'a.jpg', ms_delay: 100},
47
- ]
48
- */
49
- ```
50
-
51
- #### Create full factorial design with repeats
52
- ```javascript
53
- var factors = {
54
- stimulus: ['a.jpg', 'b.jpg'],
55
- ms_delay: [100, 200]
56
- }
57
-
58
- var full_design = jsPsych.randomization.factorial(factors, 2);
59
-
60
- /*
61
- output:
62
- full_design = [
63
- {stimulus: 'b.jpg', ms_delay: 200},
64
- {stimulus: 'b.jpg', ms_delay: 100},
65
- {stimulus: 'b.jpg', ms_delay: 100},
66
- {stimulus: 'a.jpg', ms_delay: 100},
67
- {stimulus: 'a.jpg', ms_delay: 200},
68
- {stimulus: 'b.jpg', ms_delay: 200},
69
- {stimulus: 'a.jpg', ms_delay: 100},
70
- {stimulus: 'a.jpg', ms_delay: 200},
71
- ]
72
- */
73
- ```
74
-
75
- #### Create full factorial design, unpacked
76
- ```javascript
77
- var factors = {
78
- stimulus: ['a.jpg', 'b.jpg'],
79
- ms_delay: [100, 200]
80
- }
81
-
82
- var full_design = jsPsych.randomization.factorial(factors, 1, true);
83
-
84
- /*
85
- output:
86
- full_design = {
87
- stimulus: ['a.jpg','b.jpg','b.jpg','a.jpg'],
88
- ms_delay: [200, 100, 200, 100]
89
- ]
90
- */
91
- ```
92
-
93
- ---
94
- ## jsPsych.randomization.randomID
95
-
96
- ```
97
- jsPsych.randomization.randomID(length)
98
- ```
99
-
100
- ### Parameters
101
-
102
- Parameter | Type | Description
103
- ----------|------|------------
104
- length | integer | The length of the randomly generated ID
105
-
106
- ### Return value
107
-
108
- Returns a string of length `length` where each character is randomly selected from the numbers 0-9 and all lowercase English letters a-z.
109
-
110
- ### Description
111
-
112
- Generates a random string that is likely to be unique. If length is undefined, then the string length is 32.
113
-
114
- ### Example
115
-
116
- ```javascript
117
-
118
- console.log(jsPsych.randomization.randomID());
119
- // outputs: "t7dwz0e713pc8juuaayyfvpkdd9un239"
120
-
121
- console.log(jsPsych.randomization.randomID(8));
122
- // outputs: "3xtpcbck"
123
-
124
- ```
125
-
126
- ---
127
- ## jsPsych.randomization.repeat
128
-
129
- ```
130
- jsPsych.randomization.repeat(array, repetitions, unpack)
131
- ```
132
-
133
- ### Parameters
134
-
135
- Parameter | Type | Description
136
- ----------|------|------------
137
- array | array | The array of values to randomize & repeat.
138
- repetitions | integer or array | The number of times to repeat each element of the `array` in the final sample. If this parameter is defined as an integer, then each element of `array` is repeated the same number of times. This parameter can also be an array of the same length as `array`, in which case each element of `array` will be repeated the number of times defined in the corresponding position of the `repetitions` array.
139
- unpack | boolean | If each element of `array` is an object with an equivalent set of properties, then setting `unpack` to `true` will make the return value an object with a property for each of the unique properties among the elements of the `array`. Each property in the output object will be an array containing the values for that property in the randomized order. The order will be consistent across properties. If this is `false` then the output is just an array containing a randomized order of the original `array` elements.
140
-
141
- ### Return value
142
-
143
- The return value depends on the `unpack` parameter. See description of the parameter above, and examples below.
144
-
145
- ### Description
146
-
147
- This method takes an array of values and generates a new random order of the array, with the option of repeating each element of the array a specified number of times.
148
-
149
- If the array elements are objects with the same set of properties, then this method can optionally return a single object where each property is a randomized order of the properties defined in the original set of objects. This is useful for randomizing sets of parameters that are used to define a jsPsych block.
150
-
151
- ### Examples
152
-
153
- #### Shuffle an array, no repeats
154
-
155
- ```javascript
156
-
157
- var myArray = [1,2,3,4,5];
158
- var shuffledArray = jsPsych.randomization.repeat(myArray, 1);
159
-
160
- // output: shuffledArray = [3,2,4,1,5]
161
- ```
162
-
163
- #### Shuffle an array with repeats
164
-
165
- ```javascript
166
-
167
- var myArray = [1,2,3,4,5];
168
- var shuffledArray = jsPsych.randomization.repeat(myArray, 2);
169
-
170
- // output: shuffledArray = [1,3,4,2,2,4,5,1,5,3]
171
- ```
172
-
173
- #### Shuffle an array of objects
174
-
175
- ```javascript
176
-
177
- var trial1 = {
178
- stimulus: 'img/faceA.jpg',
179
- correct_key: 80,
180
- person_name: 'Joe'
181
- }
182
-
183
- var trial2 = {
184
- stimulus: 'img/faceB.jpg',
185
- correct_key: 80,
186
- person_name: 'Fred'
187
- }
188
-
189
- var trial3 = {
190
- stimulus: 'img/faceC.jpg',
191
- correct_key: 81,
192
- person_name: 'Mary'
193
- }
194
-
195
- var myArray = [ trial1, trial2, trial3 ];
196
- var shuffledArray = jsPsych.randomization.repeat(myArray, 2);
197
-
198
- // output: shuffledArray = [ trial1, trial3, trial3, trial2, trial1, trial2 ]
199
- ```
200
-
201
- #### Shuffle an array of objects, with unpack
202
-
203
- ```javascript
204
-
205
- var trial1 = {
206
- stimulus: 'img/faceA.jpg',
207
- correct_key: 80,
208
- person_name: 'Joe'
209
- }
210
-
211
- var trial2 = {
212
- stimulus: 'img/faceB.jpg',
213
- correct_key: 80,
214
- person_name: 'Fred'
215
- }
216
-
217
- var trial3 = {
218
- stimulus: 'img/faceC.jpg',
219
- correct_key: 81,
220
- person_name: 'Mary'
221
- }
222
-
223
- var myArray = [ trial1, trial2, trial3 ];
224
- var shuffledArray = jsPsych.randomization.repeat(myArray, 2, true);
225
-
226
- /*
227
- output: shuffledArray = {
228
- stimulus: ['img/faceB.jpg','img/faceA.jpg','img/faceC.jpg','img/faceA.jpg','img/faceC.jpg','img/faceB.jpg'],
229
- correct_key: [80, 80, 81, 80, 81, 80],
230
- person_name: ['Fred','Joe', 'Mary', 'Joe', 'Mary', 'Fred']
231
- }
232
- */
233
- ```
234
- ---
235
- ## jsPsych.randomization.sampleWithReplacement
236
-
237
- ```
238
- jsPsych.randomization.sampleWithReplacement(array, sampleSize, weights)
239
- ```
240
-
241
- ### Parameters
242
-
243
- Parameter | Type | Description
244
- ----------|------|------------
245
- array | array | The array of values to sample from
246
- sampleSize | numeric | The number of samples to draw
247
- weights | array | The relative weight of each element in `array`. This array is normalized, so the values do not need to sum to 1. The length must match the length of `array`.
248
-
249
- ### Return value
250
-
251
- An array containing the sample.
252
-
253
- ### Description
254
-
255
- This method returns a sample drawn at random from a set of values with replacement. The relative probability of drawing each item can be controlled by specifying the `weights`.
256
-
257
- ### Examples
258
-
259
- #### Sample with equal probability
260
-
261
- ```javascript
262
-
263
- var myArray = [1,2,3,4,5];
264
- var sample = jsPsych.randomization.sampleWithReplacement(myArray, 10);
265
-
266
- // output: sample = [3, 1, 2, 2, 5, 1, 4, 3, 1, 5];
267
- ```
268
-
269
- #### Sample with unequal probability
270
-
271
- ```javascript
272
-
273
- var myArray = [1,2,3,4,5];
274
- var sample = jsPsych.randomization.sampleWithReplacement(myArray, 10, [6,1,1,1,1]);
275
-
276
- // output: sample = [3, 4, 5, 1, 2, 1, 3, 1, 1, 1];
277
- ```
278
-
279
- ---
280
- ## jsPsych.randomization.sampleWithoutReplacement
281
-
282
- ```
283
- jsPsych.randomization.sampleWithoutReplacement(array, sampleSize)
284
- ```
285
-
286
- ### Parameters
287
-
288
- Parameter | Type | Description
289
- ----------|------|------------
290
- array | array | The array of values to sample from
291
- sampleSize | numeric | The number of samples to draw
292
-
293
- ### Return value
294
-
295
- An array containing the sample.
296
-
297
- ### Description
298
-
299
- This method returns a sample drawn at random from a set of values without replacement. The sample size must be less than or equal to the length of the array.
300
-
301
- ### Examples
302
-
303
- #### Sample without replacement
304
-
305
- ```javascript
306
-
307
- var myArray = [1,2,3,4,5];
308
- var sample = jsPsych.randomization.sampleWithoutReplacement(myArray, 2);
309
-
310
- // output: sample = [3,2];
311
- ```
312
-
313
- ---
314
- ## jsPsych.randomization.shuffle
315
-
316
- ```
317
- jsPsych.randomization.shuffle(array)
318
- ```
319
-
320
- ### Parameters
321
-
322
- Parameter | Type | Description
323
- ----------|------|------------
324
- array | array | The array of values to shuffle
325
-
326
- ### Return value
327
-
328
- Returns an array with the same elements as the input array in a random order.
329
-
330
- ### Description
331
-
332
- A simple method for shuffling the order of an array.
333
-
334
- ### Examples
335
-
336
- #### Shuffle an array
337
-
338
- ```javascript
339
-
340
- var myArray = [1,2,3,4,5];
341
- var shuffledArray = jsPsych.randomization.shuffle(myArray);
342
-
343
- // output: shuffledArray = [3,2,4,1,5]
344
- ```
345
-
346
- ---
347
- ## jsPsych.randomization.shuffleNoRepeats
348
-
349
- ```
350
- jsPsych.randomization.shuffleNoRepeats(array, equalityTest)
351
- ```
352
-
353
- ### Parameters
354
-
355
- Parameter | Type | Description
356
- ----------|------|------------
357
- array | array | The array of values to shuffle
358
- equalityTest | function | A function to use to evaluate the equality of neighbors in the array. The function should accept two parameters, which are the two elements to be tested. It should return `true` if they are equal and `false` if not. The default function, if none is specified, is to use the `===` operator. This will work for primitive values, but fail for Objects and Arrays. An example function is given below in the examples.
359
-
360
- ### Return value
361
-
362
- Returns an array with the same elements as the input array in a random order, with no repeating neighbors.
363
-
364
- ### Description
365
-
366
- Shuffle an array, ensuring that neighboring elements in the array are different.
367
-
368
- *Warning: if you provide an array that has very few valid permutations with no neighboring elements, then this method will fail and cause the browser to hang.*
369
-
370
- ### Examples
371
-
372
- #### Basic example
373
-
374
- ```javascript
375
-
376
- var myArray = [1,2,3,4,5,1,2,3,4,5,1,2,3,4,5];
377
- var shuffledArray = jsPsych.randomization.shuffleNoRepeats(myArray);
378
-
379
- // output: shuffledArray = [2, 3, 5, 1, 2, 4, 1, 5, 4, 1, 3, 5, 4, 3, 2]
380
- ```
381
-
382
- #### Custom equalityTest
383
-
384
- ```javascript
385
- var myObjects = [
386
- {color:"blue"},
387
- {color:"red"},
388
- {color:"yellow"},
389
- {color:"orange"}
390
- ];
391
-
392
- var repeatedSet = jsPsych.randomization.repeat(myObjects,3);
393
- var shuffled = jsPsych.randomization.shuffleNoRepeats(repeatedSet, function(a,b) { return a.color === b.color });
394
-
395
- // console.log(JSON.stringify(shuffled))
396
- // "[{"color":"red"},{"color":"yellow"},{"color":"blue"},{"color":"yellow"},{"color":"orange"},{"color":"red"},{"color":"yellow"},{"color":"orange"},{"color":"blue"},{"color":"orange"},{"color":"red"},{"color":"blue"}]"
397
- ```
@@ -1,102 +0,0 @@
1
- # jsPsych.turk
2
-
3
- The jsPsych.turk module contains functions for interacting with Mechanical Turk.
4
-
5
- ---
6
- ## jsPsych.turk.submitToTurk
7
-
8
- ```
9
- jsPsych.turk.submitToTurk(data)
10
- ```
11
-
12
- ### Parameters
13
-
14
- Parameter | Type | Description
15
- ----------|------|------------
16
- data | object | The `data` parameter is an object of `key: value` pairs. Any pairs in the `data` parameter will be saved by Mechanical Turk, and can be downloaded in a CSV file through the Mechanical Turk interface. **Important**: the `data` parameter must contain at least one `key: value` pair, even just a dummy value, or the HIT will not be submitted correctly.
17
-
18
- ### Return value
19
-
20
- Returns nothing.
21
-
22
- ### Description
23
-
24
- This method will submit a HIT to Mechanical Turk, causing the HIT to finish.
25
-
26
- This method will only work when called from within the mechanical turk website. If you are using an external HIT to send workers to your own server, this method will not work on an externally hosted page. It will work if your external content is loaded in the iframe on the Mechanical Turk website.
27
-
28
- ### Example
29
-
30
- ```html
31
-
32
- <p>Enter the code you were given:</p>
33
- <input type="text" id="code"></input>
34
- <button onclick="sendData();">Submit HIT</button>
35
-
36
- <script>
37
- // this content must be loaded in the iframe on the mechanical turk website.
38
- // usually, this means that the content is part of your 'recruitment ad', the
39
- // page the workers can see when they are deciding whether or not to accept a HIT.
40
- // one option is to include a simple form on this page that workers submit, with a
41
- // special code that they get at the end of the experiment.
42
-
43
- function sendData() {
44
- jsPsych.turk.submitToTurk({
45
- code: document.getElementById('code').value
46
- });
47
- }
48
- </script>
49
- ```
50
-
51
- ---
52
-
53
- ## jsPsych.turk.turkInfo
54
-
55
- ```
56
- jsPsych.turk.turkInfo()
57
- ```
58
-
59
- ### Parameters
60
-
61
- None.
62
-
63
- ### Return value
64
-
65
- Returns an object with six properties:
66
-
67
- * `.assignmentId` contains the assignment ID string of the HIT.
68
- * `.hitId` contains the HIT ID.
69
- * `.workerId` contains the worker ID of the worker completing the HIT.
70
- * `.turkSubmitTo` contains the URL for submitting the HIT. This parameter is used in the `jsPsych.turk.submitToTurk` method, and is probably not useful outside of that context.
71
- * `.previewMode` is a boolean value indicating whether or not the worker has accepted the HIT yet. If the page is viewed inside Mechancial Turk and the worker has not clicked 'Accept HIT' then this will be true. If the page is viewed outside Mechanical Turk or the worker has acccepted the HIT, then it will be false.
72
- * `.outsideTurk` is a boolean value indicating if the page is being viewed within Mechanical Turk, or if it is being viewed from another source (e.g., someone directly going to the page URL instead of going through mturk).
73
-
74
- ### Description
75
-
76
- This method returns basic information about the current Mechanical Turk session, including the worker ID, assignment ID, and HIT ID.
77
-
78
- ### Example
79
-
80
- ```javascript
81
-
82
- var turkInfo = jsPsych.turk.turkInfo();
83
-
84
- alert('Worker ID is: ' + turkInfo.workerId);
85
-
86
- alert('Assignment ID is: ' + turkInfo.assignmentId);
87
-
88
- alert('HIT ID is: ' + turkInfo.hitId);
89
-
90
- // true if the page is viewed within Mechanical Turk,
91
- // but worker has not accepted the HIT yet.
92
- // false if the page is viewed outside Mechanical Turk,
93
- // OR the worker has accepted the HIT.
94
- alert('Preview mode? ' + turkInfo.previewMode);
95
-
96
- // true if the page is viewed outside mechanical turk,
97
- // false otherwise.
98
- alert('Outside turk? ' + turkInfo.outsideTurk);
99
- ```
100
-
101
-
102
-
package/docs/img/blue.png DELETED
Binary file
Binary file
Binary file
Binary file
Binary file