A program to make it easier to write online experiments. Speriment takes a simple description of your experiment in Python and uses it to run online experiments with the use of PsiTurk and Mechanical Turk.
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
bin
css
doc
speriment
test
typescript
typings
.gitignore
.npmignore
LICENSE
MANIFEST.in
README.md
package.json
setup.py
tsd.json

README.md

#Speriment

##Making experiments easier to express

###What is Speriment? Speriment is a package, inspired by SurveyMan, to help you write an online experiment for use with PsiTurk. PsiTurk describes itself as a tape player - it can run any "tape", that is, JavaScript program, as an online experiment on Mechanical Turk. But you have to provide the tape. Speriment allows you to write a simple Python script, using only the most basic programming skills, to create that JavaScript program. Instead of writing your own code to shuffle items, display HTML, record answers, and so on, you simply describe the structure and contents of your experiment.

It's currently in beta. It should work on any Unix machine but has only been tested on a Mac. Please add an Issue if you find any bugs.

###Guides

Speriment experiments are made by nesting Python objects.

To get started, look at this example script to see the basics.

Then you can look for the specific features you need here. Features you may be interested in include:

  • counterbalancing
  • Latin Squares
  • pseudorandomization
  • training loops
  • multi-page items (such as for self-paced reading tasks)
  • optional keyboard-only response selection (better for collecting response times)
  • distribution of text and resources on a per-participant basis
  • condition presentation of items depending on previous responses

For help with the syntax while writing your script, check out the API at RawGit.

The workflow for installing and running Speriment is explained here. A description of the output you'll analyze is given here.

###How do I contribute?

Contributions are super welcome. But before you start coding, start an Issue or comment on an existing one. There are lots of new features to add, and we want to make sure they'll play nice together before anyone spends time implementing stuff.