Python脚本不工作?:播放声音,测量反应时间

2024-09-25 18:27:56 发布

您现在位置:Python中文网/ 问答频道 /正文

我想做一个脚本,用来衡量参与者按回车键或空格键的速度,只有当他们听到声音文件中2/30的声音时。 因此,有时用户不必按任何键,脚本仍会转到下一个声音文件。我该怎么做?我现在拥有的是:(不是声音文件,而是文本文件):

# Grounding of Words Experiment #

#Import libraries
import re
import glob
from psychopy import sound, visual, event, data, core, gui # imports a module for visual presentation and one for controlling events like key presses


# ID, age, gender box display
myDlg = gui.Dlg(title="Experiment") #, pos=(400,400)
myDlg.addField('ID:')
myDlg.addField('Age:')
myDlg.addField('Gender:', choices = ['Female', 'Male'])
myDlg.show()#you have to call show() for a Dlg
if myDlg.OK:
    ID = myDlg.data[0]
    Age = myDlg.data[1]
    Gender = myDlg.data[2]
else:
    core.quit()

trial=0

#Creates the outfile, that will be the file containing our data, the name of the file, as saved on the computer is the filename
out_file="Grounding_experiment_results.csv"
#Creates the header for the data
header="trial,ID,Gender,Age,Word,rt,SpaceKlik\n"
#opens the outfile in writemode
with open(out_file,"w") as f:
    f.write(header)#writes the header in the outfile


# define window
win = visual.Window(fullscr=True) # defines a window using default values (= gray screen, fullscr=False, etc)

# Instruction box display

def instruct(txt):
    instructions = visual.TextStim(win, text=txt, height = 0.05) # create an instruction text
    instructions.draw() # draw the text stimulus in a "hidden screen" so that it is ready to be presented 
    win.flip() # flip the screen to reveal the stimulus
    event.waitKeys() # wait for any key press

instruct('''
Welcome to the experiment!

You will be hearing different words.
Whenever you hear the word "Klik" and "Kast" please press the left mouse button.
Whenever you hear any other word - do nothing.
Try to be as fast and accurate as possible.
Please put on the headphones. 
The experiment will take 5 minutes. 

Press any key to start the experiment''')

# Play sound

# Function that makes up a trial

trial(word):
    global trial
    trial += 1
    if word in ["Klik", "Press", "Throw"]:
        condition = "press"
    else :
        condition = "no_press"
    event.clearEvents()
    for frame in range(90):
        text = visual.TextStim(win, text=word, height = 0.05)
        text.draw() # draw the text stimulus in a "hidden screen" so that it is ready to be presented 
        time_start=win.flip()
    try:
        key, time_key=event.getKeys(keyList=['space', 'escape'], timeStamped = True)[0] # wait for any key press
    except IndexError:
        key = "0"
        rt = "NA"
    else:
        if key=='escape': 
                core.quit()
        rt = time_key - time_start
    if key == "space" and condition=="press":
        accuracy = 1
    elif key == "0" and condition=="no_press":
        accuracy = 1
    else:
        accuracy = 0
    with open(out_file,"a") as f:
        f.write("{},{},{},{},{},{},{},{}\n".format(trial,ID,Gender,Age,word,accuracy,rt,SpaceKlik))

# s = sound.Sound('sound.wav') 
# s.play()

# Register space bar press or mouse click

# Measure reaction time

# Check to see if answer is correct to sound - certain sound files are "klik". Others "kast", "løb", "sko" and so on

# Write csv logfile with coloumns: "ID", "Gender", "Word", "Correct/incorrect", "Reaction time", "Space/click"

我最终都会精神错乱。感谢贵方的合作。你知道吗


Tags: andthetokeytextinidfor
2条回答

好的,很好-谢谢!现在我继续尝试开发你的脚本。我增加了一份试用名单,现在我不太确定该怎么办。我的脚本如下所示:

# Grounding of Words Experiment #

# -*- coding: utf-8 -*-

#Import libraries
import re
import glob
from psychopy import sound, visual, event, data, core, gui # imports a module for visual presentation and one for controlling events like key presses
import ppc

# ID, age, gender box display
myDlg = gui.Dlg(title="Experiment") #, pos=(400,400)
myDlg.addField('ID:')
myDlg.addField('Age:')
myDlg.addField('Gender:', choices = ['Female', 'Male'])
myDlg.show()#you have to call show() for a Dlg
if myDlg.OK:
    ID = myDlg.data[0]
    Age = myDlg.data[1]
    Gender = myDlg.data[2]
else:
    core.quit()

# define window
win = visual.Window(fullscr=True)


# function to draw instructions (probably overkill unless run more than once)
def instruct(txt):
    instructions = visual.TextStim(win, text=txt, height = 0.05) # create an instruction text
    instructions.draw() # draw the text stimulus in a "hidden screen" so that it is ready to be presented 
    win.flip() # flip the screen to reveal the stimulus
    event.waitKeys() # wait for any key press
    # as you have above


# function to run each trial
def trial(number = -999, sound_name = 'A'):

    sound = Sound.sound()

    if sound_name in ["dog-howling.wav"]:
        condition = "press"
    else:
        condition = "no_press"

    event.clearEvents()

    sound.play(sound_name)

    for frame in range(90):

        time_start = win.flip()

        keys = event.getKeys(keyList=['space', 'escape'], timeStamped = True)
        if keys: # if a non-empty list returned:
            key, time_key = keys[0]
            rt = time_key - time_start

            sound.stop() # ready to start next trial immediately

            if key == 'escape': 
                core.quit()

            if condition == "press":
                return {'accuracy':1, 'rt':rt}
            else:
                return {'accuracy':0, 'rt':rt}

    else: # the loop ended without a key press
        if condition == "press":
            return {'accuracy':0, 'rt':'NA'}
        else:
            return {'accuracy':1, 'rt':'NA'}
####
# define triallist

trial_list = []
conditions = ["klik", "notklik"]
sounds = ["dog-howling.wav", "sound2.wav", "sound3.wav"]
for condition in conditions:
    for sound in sounds:
        # Add a dictionary for every trial
            trial_list += [{
                'ID': ID,
                'age': AGE,
                'gender': GENDER,
                'condition': condition,
                'sounds': sound,
                'rating': '',
                'rt': ''
                    }]

# Randomize order
trial_list = sample(trial_list, len(trial_list))

# Add trial numbers
for i, trial in enumerate(trial_list):
    trial['no'] = i + 1 # start at 1

# write file

####
# run the experiment:
####

####
# show the instructions:
####
instruct('''Welcome to the experiment!

You will be hearing different words.
Whenever you hear the word "Klik" and "Kast" please press the left mouse button.
Whenever you hear any other word - do nothing.
Try to be as fast and accurate as possible.
Please put on the headphones. 
The experiment will take 5 minutes. 

Press any key to start the experiment''')

####
# run the trials:
####
for trial_num in range(10):

    # run each trial and get the results.
    # I'm not sure where you're getting your sound values
    # but they could be indexed from a list using the trial number:
    result = trial(number=trial_num, sound_name=sound_names[trial_num])

    # then save the values from the returned dictionary to a file+

#Creates the outfile, that will be the file containing our data, the name of the file, as saved on the computer is the filename
#out_file="Grounding_experiment_results.csv"
#Creates the header for the data
#header="trial,ID,Gender,Age,Word,rt,SpaceKlik\n"
#opens the outfile in writemode
#with open(out_file,"w") as f:
#    f.write(header)#writes the header in the outfile

缩进有问题,因此不是所有的东西都在适当级别的试用函数中运行。您可能可以删除异常处理来更直接地检查是否做出了响应。然后使用else:子句处理for循环完成但未按下任何键时发生的情况。这避免了必须处理在任何给定帧上发生的非响应的逻辑(如果不久之后将发生响应,则这可能没有任何意义)。你知道吗

类似这样的通用伪代码:

# define window
win = visual.Window(fullscr=True)

# function to draw instructions (probably overkill unless run more than once)
def instruct(instructions = 'xxx'):
    # as you have above

# function to run each trial
def trial(number = -999, sound_name = 'A'):

    sound = Sound.sound(sound_name)

    if sound_name in ["Klik.wav", "Press.wav", "Throw.wav"]:
        condition = "press"
    else:
        condition = "no_press"

    event.clearEvents()

    sound.play()

    for frame in range(90):

        time_start = win.flip()

        keys = event.getKeys(keyList=['space', 'escape'], timeStamped = True)
        if keys: # if a non-empty list returned:
            key, time_key = keys[0]
            rt = time_key - time_start

            sound.stop() # ready to start next trial immediately

            if key == 'escape': 
                core.quit()

            if condition == "press":
                return {'accuracy':1, 'rt':rt}
            else:
                return {'accuracy':0, 'rt':rt}

    else: # the loop ended without a key press
        if condition == "press":
            return {'accuracy':0, 'rt':'NA'}
        else:
            return {'accuracy':1, 'rt':'NA'}

####
# run the experiment:
####

####
# show the instructions:
####
instruct('some instructions')

####
# run the trials:
####
for trial_num in range(10):

    # run each trial and get the results.
    # I'm not sure where you're getting your sound values
    # but they could be indexed from a list using the trial number:
    result = trial(number=trial_num, sound_name=sound_names[trial_num])

    # then save the values from the returned dictionary to a file

相关问题 更多 >