精神病建设者实验与反馈和多个if循环

2024-10-01 15:36:30 发布

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

我试着用一个条件反馈的观点来做一个实验。你怎么做到的?这项任务最终将涉及4道数学题,每个问题允许参与者最多尝试3次。结构应该是这样的。。。在

循环1:通过4个问题

循环2:每个问题最多允许3次尝试

循环3:如果回答是正确的,那么说“正确”并进入下一个问题;否则,说“不正确”,询问他们是否愿意再试一次或继续

这是我第一次使用Python,我无法解决代码中的问题。没有返回错误消息,而是代码没有注册响应,因此任务在提示屏幕上被冻结。代码如下。我没有包括图书馆和其他设施。在

t=0
nProblem=4
nAttempt=3

while currentProb <= nProblem:
    problemTimer.reset()
    attempt = 1

    # *prompt* updates
    prompt.setAutoDraw(True)
    prompt.setText(u'Problem prompt will go here.\n\nType in your answer and press enter to submit.', log=False)

    while attempt <= nAttempt:

        response = []
        # *response* updates
        core.wait(1) #LB - using this in place of that enormous if-statement

        event.clearEvents(eventType='keyboard')
        theseKeys = event.getKeys(keyList=['1', '2', '3', '4', '5', '6', '7', '8', '9', '0'])
        # check for quit:
        if "escape" in theseKeys:
            endExpNow = True
        if ('1', '2', '3', '4', '5', '6', '7', '8', '9', '0') in theseKeys: # subject responds with number value
            response.append(theseKeys) # will tack on responses to previous responses

        while event.getKeys(keyList=['return'])==[]:

            # *timer* updates
            if t <= 0.0:
                # keep track of start time/frame for later
                timer.setAutoDraw(True)
            #elif timer.status == STARTED and t >= (0.0 + (600-win.monitorFramePeriod*0.75)): #most of one frame period left
                #timer.setAutoDraw(False)
            #if timer.status == STARTED:  # only update if being drawn
                timer.setText(str(round((600+routineTimer.getTime())/60,1)) , log=False)

            # *minutesleft* updates
            if t >= 0.0:
                # keep track of start time/frame for later
                minutesleft.setAutoDraw(True)
            #elif minutesleft.status == STARTED and t >= (0.0 + (600-win.monitorFramePeriod*0.75)): #most of one frame period left
            #minutesleft.setAutoDraw(False)

            numberlist=event.getKeys(keyList=['1','2','3','4','5','6','7','8','9','0','backspace','return'])
            for number in numberlist:
                #if key isn't backspace, add key pressed to the string
                if number !='backspace':
                    response.append(number)
                #otherwise, take the last letter off the string
                elif len(text)>=0:
                    response.remove(numberlist[number-1])
            #continually redraw text onscreen until return pressed
            answer = visual.TextStim(win, text=response,color="black",pos=(0,-100))
            answer.draw()
            win.flip()
            event.clearEvents()

        if len(theseKeys) > 0:  # at least one key was pressed
            response.keys.extend(theseKeys)  # storing all keys
            response.rt.append(response.clock.getTime())

        #check for quit
        if "escape" in theseKeys:
            endExpNow = True

        if response == '9999': # was this correct?
            correctAns = 1
        else: 
            correctAns = 0
        if theseKeys == 'enter':
            response.keys.extend(theseKeys) # storing all keys
            response.rt.append(attemptresponse.clock.getTime())
            if correctAns == 1:
                attempt += 888 #ends and goes to next problem
                currentProb += 1
                dataFile.write(attempt,attemptresponse,theseKeys,response,correctAns) #output separated by commas
                #dataFile.write('PID    COND    PROB    ATT TIME    RESP\n')
                response_correct.draw()
                win.flip()
                event.waitKeys()
            if correctAns == 0:
                attempt += 1 #LB = was previously setting to 1 forever
                dataFile.write(attempt-1,attemptresponse,theseKeys,response,correctAns) #output separated by commas
                response_incorrect.draw()
                win.flip()
                theseKeys = event.getKeys(keyList=['q','space'])
                if theseKeys == 'q':
                    continueRoutine = False
                if theseKeys == 'space':
                    prompt.draw()
                    win.flip()
                    event.waitKeys()

Tags: oftoineventfalsetrueifresponse
1条回答
网友
1楼 · 发布于 2024-10-01 15:36:30

我不能写完整的代码,但希望能指出一些事情,让你走得更远。在

正在获取响应

theseKeys = event.getKeys(keyList=['1', '2', '3', '4', '5', '6', '7', '8', '9', '0'])
if "escape" in theseKeys:

这里theseKeys只能包含keyList中的内容,所以“escape”永远不会出现。用“escape”和“enter”扩展keyList,您以后会用到它。在

^{pr2}$

theseKeys是一个列表,当您在list中执行“(x,y,z)操作时,它将查找一个元素(x,y,z),而不是x,y和z的任何出现。如果您有上面的keyList,您就知道任何非转义响应都是其中之一,所以它是不必要的。我也是

theseKeys = event.getKeys(keyList=['1', '2', '3', '4', '5', '6', '7', '8', '9', '0', 'escape'])
if "escape" in theseKeys:
    core.quit()  # assuming that psychopy.core is imported
elif "enter" in theseKeys:
    # Something something
else:
   response.append(theseKeys[0])  # OBS: pick the first response

循环

看起来您确实希望使用for循环,而不是while循环。使用for循环,您不必跟踪当前循环编号。所以不是

while currentProb <= nProblem:

for currentProb in range(nProblem):

然后,currentProb的增量会自动发生,循环将在应该的时候终止。如果可能的话,这会更优雅。在

正在等待响应

我有点怀疑您是否希望在while循环中使用event.waitKeys()而不是event.getKeys(),如果您想控制等待时间,那么使用maxWait参数来跟踪时间。如果您想设置动画,while循环是可以的,但是如果不想,那么event.waitKeys()将更简单、更安全。在

最后,当您尝试实现这一点时,使用大量print语句来检查theseKeys和其他变量的实际内容。这是调试和捕获陷阱的最佳方法。在

相关问题 更多 >

    热门问题