从线程段错误运行Psychopy窗口

时间:2015-06-11 11:08:50

标签: multithreading psychopy

我正在尝试从一个单独的线程运行我的Psychopy窗口,并控制另一个线程上显示的内容,但我得到的只是致命的Python错误。

这是一个小例子脚本,它产生与我较大的

相同的结果
from threading import Thread
from psychopy import visual, core
import time

class ThreadTest(Thread):
    def __init__(self):
        Thread.__init__(self)
        self.text='Test'
        self.running = 1
        self.start()
        print 'doing stuff'

    def run(self):
        win = visual.Window()

        msg = visual.TextStim(win, text=self.text)
        while self.running:
            msg.setText(self.text)
            msg.draw()
            win.flip()
            print 'Drawing...'
            core.wait(2)

        win.close()
        print 'Stopping thread'

    def setText(self, text):
        self.text=text

    def stopTest(self):
        self.running = 0


def main():
    tt = ThreadTest()
    time.sleep(3)
    tt.setText('Test2')
    time.sleep(3)
    tt.stopTest()
    print 'Stopping main thread'

if __name__ == '__main__':
    main()

和输出

python testy.py 
doing stuff
Fatal Python error: (pygame parachute) Segmentation Fault
Aborted (core dumped)

这会创建Psychopy窗口,但无法在其上显示任何文本然后崩溃。我也尝试在__init__()中创建窗口,但这也不起作用。

2 个答案:

答案 0 :(得分:1)

这似乎是文本对象的一个​​问题,它来自pyglet,可能会干扰pyglet线程。下面的代码实际上有效(令我惊讶的是)!

但是你做了一些强烈劝阻并且不受支持的事情。 OpenGL调用(处理所有渲染)不是线程安全的,不应该从主线程以外的任何东西调用。

基本上,你是从这里自己做的! ; - )

from threading import Thread
from psychopy import visual, core
import time

class ThreadTest(Thread):
    def __init__(self):
        Thread.__init__(self)
        self.ori=0
        self.running = 1
        print 'initialised'

    def run(self):
        win = visual.Window()
        print 'created window'
        stim = visual.PatchStim(win)
        print 'created stim'
        while self.running:
            stim.ori = self.ori
            stim.draw()
            win.flip()
            print '.',
            core.wait(0.01)

        print 'Stopping auxil thread'

    def setOri(self, ori):
        self.ori=ori

    def stopTest(self):
        self.running = 0


def main():
    tt = ThreadTest()
    tt.start()
    for frameN in range(180):
        tt.setOri(frameN)
        time.sleep(0.01)
    tt.stopTest()
    print 'Stopping main thread'

if __name__ == '__main__':
    main()

答案 1 :(得分:0)

罪魁祸首确实是主循环中没有的TextStim。当我交换主要和drawloops时,它开始工作。现在我只需要找到一种方法来阻止新线程,即使它正在做某事。

from threading import Thread
from psychopy import visual, core
import time

class ThreadTest(Thread):
    def __init__(self):
        Thread.__init__(self)
        self.text='Test'
        self.running = 1

        print 'doing stuff'

    def run(self):
        time.sleep(3)
        self.setText('Test2')
        time.sleep(3)
        self.stopTest()

    def mainloop(self):
        win = visual.Window()
        while self.running:

            msg = visual.TextStim(win)
            msg.setText(self.text)
            msg.draw()
            win.flip()
            print 'Drawing...'
            core.wait(2)
        win.close()
        print 'Stopping thread'

    def setText(self, text):
        self.text=text

    def stopTest(self):
        self.running = 0


def main():
    tt = ThreadTest()
    tt.start()
    tt.mainloop()
    print 'Stopping main thread'

if __name__ == '__main__':
    main()