Main content

06. Sample experiment: Priming Design

Menu

Loading wiki pages...

View
Wiki Version:
**NOTE: this page assumes you are familiar with notions covered in [this page][1] and [this page][2].** *Next: [How to use a spreadsheet][5]* @[toc](Sections) ### Setup Create a new experiment on Ibex. Click on Update from git repo and enter the following URL: `https://github.com/PennController/Sample-Experiment-Priming-Design-beta0.4.git`, then click on the Sync button. You should see a confirmation message appear below the button, reading Success: N file modified. If you don't see the message, try clicking again. If it still does not work, reload your Ibex page and try again. *Warning*: whenever you click on Sync, the file example_data gets erased and reverts back to the code in the Basics section below. ### Basics OK, so now we know how to build simple trials. But the design of a full experiment usually consists of more than one screen where to click a button or type a word. Let us consider a priming design: we want our participants to report how warm they perceive a color after picking between two color patches. To start with, what we want is simply create one trial of each type. The code below combines and adapts some code from the *[Picture selection][3]* page and from the page *[Rating scale][4]* page. Note: In order to have the PennController functions available, keep working on one of the experiments you created, but copy and paste the code below to replace the full content of *example_data.js*. (Creating a new experiment without importing the PennController files from Github will not work!) ```js var shuffleSequence = seq("trial"); PennController.ResetPrefix(null); PennController.AddHost("http://files.lab.florianschwarz.net/ibexfiles/PennController/SampleTrials/"); var items = [ // Picture selection trial ["trial", "PennController", PennController( defaultImage .settings.size(200, 200) , newText("test sentence", "Which patch is greener?") .print() , newCanvas("patches", 500, 200) .settings.add( 0, 0, newImage("color1", "green1.png") ) // Embedded image creation .settings.add( 300, 0, newImage("color2", "green2.png") ) // Embedded image creation .print() , newSelector("patch") .settings.add( getImage("color1") , getImage("color2") ) .wait() )] , // Rating trial ["trial", "PennController", PennController( newText("green", "To me the color green is...") , newScale("judgment", "cold", "cool", "lukewarm", "warm", "hot") .settings.labels("top") .settings.before( getText("green") ) .settings.size("auto") // Use max width for each cell (here, lukewarm's cell's width) .print() .wait() )] ]; ``` ### More trials This is nice, but our priming design won't be much informative if we have but one trial of each type. Let's add a second pair of trials: we simply duplicate what we already have, append it to the end and bring minimal changes. ```js var shuffleSequence = seq("trial"); PennController.ResetPrefix(null); PennController.AddHost("http://files.lab.florianschwarz.net/ibexfiles/PennController/SampleTrials/"); var items = [ // Picture selection trial (GREEN) ["trial", "PennController", PennController( defaultImage .settings.size(200, 200) , newText("test sentence", "Which patch is greener?") .print() , newCanvas("patches", 500, 200) .settings.add( 0, 0, newImage("color1", "green1.png") ) .settings.add( 300, 0, newImage("color2", "green2.png") ) .print() , newSelector("patch") .settings.add( getImage("color1") , getImage("color2") ) .wait() )] , // Rating trial (GREEN) ["trial", "PennController", PennController( newText("green", "To me the color green is...") , newScale("judgment", "cold", "cool", "lukewarm", "warm", "hot") .settings.labels("top") .settings.before( getText("green") ) .settings.size("auto") .print() .wait() )] , // Picture selection trial (PURPLE) ["trial", "PennController", PennController( defaultImage .settings.size(200, 200) , newText("test sentence", "Which patch is purpler?") .print() , newCanvas("patches", 500, 200) .settings.add( 0, 0, newImage("color1", "purple1.png") ) .settings.add( 300, 0, newImage("color2", "purple2.png") ) .print() , newSelector("patch") .settings.add( getImage("color1") , getImage("color2") ) .wait() )] , // Rating trial (PURPLE) ["trial", "PennController", PennController( newText("green", "To me the color purple is...") , newScale("judgment", "cold", "cool", "lukewarm", "warm", "hot") .settings.labels("top") .settings.before( getText("green") ) .settings.size("auto") .print() .wait() )] ]; ``` ### Trial order Good, but what if we want to ask our participants to do both picture selection trials first and both rating trials at the end? We could re-order our trials in our `items` variable, but there is a much simpler way of doing it. We just need to use different **labels** for each trial type, and refer to them in our `shuffleSequence` variable, like this (note that the order of definition in the `items` variable is still the same as above): ```js // First run all the trials labeled 'picture,' then run all the trials labled 'rating' var shuffleSequence = seq("picture", "rating"); PennController.ResetPrefix(null); PennController.AddHost("http://files.lab.florianschwarz.net/ibexfiles/PennController/SampleTrials/"); var items = [ // Picture selection trial (GREEN) ["picture", "PennController", PennController( defaultImage .settings.size(200, 200) , newText("test sentence", "Which patch is greener?") .print() , newCanvas("patches", 500, 200) .settings.add( 0, 0, newImage("color1", "green1.png") ) .settings.add( 300, 0, newImage("color2", "green2.png") ) .print() , newSelector("patch") .settings.add( getImage("color1") , getImage("color2") ) .wait() )] , // Rating trial (GREEN) ["rating", "PennController", PennController( newText("green", "To me the color green is...") , newScale("judgment", "cold", "cool", "lukewarm", "warm", "hot") .settings.labels("top") .settings.before( getText("green") ) .settings.size("auto") .print() .wait() )] , // Picture selection trial (PURPLE) ["picture", "PennController", PennController( defaultImage .settings.size(200, 200) , newText("test sentence", "Which patch is purpler?") .print() , newCanvas("patches", 500, 200) .settings.add( 0, 0, newImage("color1", "purple1.png") ) .settings.add( 300, 0, newImage("color2", "purple2.png") ) .print() , newSelector("patch") .settings.add( getImage("color1") , getImage("color2") ) .wait() )] , // Rating trial (PURPLE) ["rating", "PennController", PennController( newText("green", "To me the color purple is...") , newScale("judgment", "cold", "cool", "lukewarm", "warm", "hot") .settings.labels("top") .settings.before( getText("green") ) .settings.size("auto") .print() .wait() )] ]; ``` Now that we have conveniently labeled our trial types, we can even use the `randomize` function to present the trials within each type-sequence in a random order: ```js // randomize runs all the labeled trials in a random order var shuffleSequence = seq(randomize("picture"), randomize("rating")); ``` (The rest of the code is not reported here for brevity, as nothing else needs to be modified) ### Next Our script is getting a little long, and we only have 4 trials so far. Yet, in order to get anything of interest with our priming design, we probably want more trials than that, maybe 10 of each. At this point, it is smart to start **[using a spreadsheet to design our experiments][5]**, which will provide the values for the variable elements in each trial: the dialogue lines for the rating trials, and the sentence for the input trials. [1]: https://osf.io/t72h6/wiki/04.%20Sample%20trial:%20Picture%20selection%20%26%20Audio%20playback/ [2]: https://osf.io/t72h6/wiki/05.%20Sample%20trial:%20Rating%20scale%20%26%20Input%20box/ [3]: https://osf.io/t72h6/wiki/06.%20Sample%20trial:%20Rating%20scale/ [4]: https://osf.io/t72h6/wiki/07.%20Sample%20trial:%20Text%20input/ [5]: https://osf.io/t72h6/wiki/07.%20How%20to%20use%20a%20spreadsheet/
OSF does not support the use of Internet Explorer. For optimal performance, please switch to another browser.
Accept
This website relies on cookies to help provide a better user experience. By clicking Accept or continuing to use the site, you agree. For more information, see our Privacy Policy and information on cookie use.
Accept
×

Start managing your projects on the OSF today.

Free and easy to use, the Open Science Framework supports the entire research lifecycle: planning, execution, reporting, archiving, and discovery.