jsPsychは基本的にデータを過不足なく出力しますが、そのままだと後々集計しにくいということがよくあります。それを克服するためのポイントをまとめてみました。
以下の例では、jsPsychのバージョン7.3.0を使用しています。バージョンによって微妙に挙動が変わると思いますのでご注意ください。
なおここでは説明していませんが、日本語が文字化けするときにはこちらをご覧ください。
dataプロパティを使う
jsPsychは画面が切り替わるたびに1行ずつデータを出力します。例えば、教示の画面、注視点を呈示している画面など、実験データを分析するときには不要となるものも大量に出力されます。ですので、分析対象のデータだけを抽出するために関心のある行にラベルをつけておくと便利です。そのためには次のように data プロパティを指定します。
timeline.push({
type: jsPsychImageButtonResponse,
stimulus: 'img/happy_face_1.jpg',
choices: ['Happy', 'Sad'],
data: {block: 1}
});
{block: 1}
の部分はみなさんが分かりやすいように書き換えてOKです。上の例の出力結果は、次のようになります。
こうしておけば、エクセルのフィルター機能などを使って block が1の行だけを抽出することができます。
なお、dataプロパティには以下のようにfunctionを指定することもできます。これはdataの値を実験前に決められず、実験の最中に決める必要があるときに使います。
var trial = {
type: jsPsychSurveyText,
questions: [{prompt: "Please enter your response."}]
data: function() {
return {difficulty: current_difficulty};
}
}
本家のdataに関する解説ページ
- https://www.jspsych.org/tutorials/rt-task/#part-11-tagging-trials-with-additional-data
- https://www.jspsych.org/overview/dynamic-parameters/#storing-changing-variables-in-the-data
余計な中括弧{}やコロン:を消す方法
刺激となる人物の画像を見て、その人物の年齢を答える実験を想定しましょう。
コードはこんな感じです。
var survey_page1 = {
type: jsPsychSurveyText,
questions: [
{prompt: 'この人物は何歳くらいに見えますか?', columns: 3, required: true, name: 'Age'}
]
};
結果は以下のようになります。たしかに回答された年齢は記録されていますが、このままだと中括弧、クオーテーション、コロンなどがあって扱いにくいですよね。
こんなときにはaddToLastを使うと便利です。
var survey_page1 = {
type: jsPsychSurveyText,
questions: [
{prompt: 'この人物は何歳くらいに見えますか?', columns: 3, required: true, name: 'Age'}
],
on_finish: function(data){
jsPsych.data.get().addToLast(data.response);
}
};
こうすると以下のようにいい感じで出力されます。
なお、addToLastと似た機能を持つaddPropertiesがありますが、こちらはすべての行に同じデータが付与されます。例えば参加者を識別するための情報、参加者間要因、参加者が使用しているデバイスなど、すべての行に共通した情報を加えるときに使用します。
行がずれる問題を克服する
さて以上を踏まえて、刺激となる人物の画像を見て、最初にその人物の年齢を答えて、その後、人物の印象を答える実験を以下のように作成しました。
var survey_page1 = {
type: jsPsychSurveyText,
questions: [
{prompt: 'この人物は何歳くらいに見えますか?', columns: 3, required: true, name: 'Age'}
],
on_finish: function(data){
jsPsych.data.get().addToLast(data.response);
}
};
var survey_page2 = {
type: jsPsychSurveyMultiChoice,
questions: [
{prompt: "この人物に対する好感度を答えてください", name: 'feeling', options: ["非常に好ましくない", "やや好ましくない", "どちらでもない", "やや好ましい", "非常に好ましい"], required:true},
],
on_finish: function(data){
jsPsych.data.get().addToLast(data.response);
}
};
上のコードで問題なく動作しますが、実験結果を見ると以下のように年齢と印象の回答が同一行に入っていません。これだと分析しにくいですよね。
こんなときには、dataプロパティの中で getLastTrialData を使用します。
var survey_page2 = {
type: jsPsychSurveyMultiChoice,
questions: [
{prompt: "この人物に対する好感度を答えてください", name: 'feeling', options: ["非常に好ましくない", "やや好ましくない", "どちらでもない", "やや好ましい", "非常に好ましい"], required:true},
],
data: function(){
return jsPsych.data.getLastTrialData().values()[0].response
},
on_finish: function(data){
jsPsych.data.get().addToLast(data.response);
}
};
直前の画面(年齢を回答させる試行)のデータを取得して、回答結果をdataプロパティに指定します。このときfunctionを使う必要がある点に注意してください。
無事に同一行にデータが入りました。
補足
上の例では、dataプロパティに直前の試行の反応だけを指定すればよかったのですが、他にも実験条件などを追加したいことがあるかもしれません。
そのときには以下のような書き方ができます。
data: function(){
var tmp_object = {
file_name: jsPsych.timelineVariable('file_name'),
block: 1
}
return Object.assign(tmp_object, jsPsych.data.getLastTrialData().values()[0].response)
},
jsPsych.data.getLastTrialData().values()[0].response
はオブジェクトなのですが、これとは別に保存したいオブジェクト(tmp_object
)を作成して、Object.assignで結合します。2つのオブジェクトを結合して新たに作成されたオブジェクトをreturn
で返すようにします。
Chromeのデベロッパーツールのすすめ
以上の説明だけで理解するのは、なかなか大変だと思います。さらに理解を深めたいかたは、上のコードのdataプロパティの箇所を次のように書き換えて実行してみてください。
data: function(){
console.log(jsPsych.data.getLastTrialData())
console.log(jsPsych.data.getLastTrialData().values())
console.log(jsPsych.data.getLastTrialData().values()[0])
console.log(jsPsych.data.getLastTrialData().values()[0].response)
return jsPsych.data.getLastTrialData().values()[0].response
},
console.logの内容は、Chromeのデベロッパーツールを使って確認するのがおすすめです。それぞれの行が、いったいどんな内容を出力するかを確認すると、きっと理解が深まるはずです!