我正在使用PyQtGraph快速可视化我的数据采集。为此,我使用while
循环不断重绘数据。该代码的简化版本由:
import time
import numpy
import pyqtgraph as pg
from pyqtgraph.Qt import QtGui, QtCore
x = numpy.linspace(-2 * numpy.pi, 2 * numpy.pi, 1000)
y = numpy.cos(x)
# Plot
win = pg.GraphicsWindow()
win.resize(800, 800)
p = win.addPlot()
p.plot(x, y, pen = "y")
i = 0
while i < 5000:
start_time = time.time()
noise = numpy.random.normal(0, 1, len(y))
y_new = y + noise
p.plot(x, y_new, pen = "y", clear = True)
p.enableAutoRange("xy", False)
pg.QtGui.QApplication.processEvents()
i += 1
end_time = time.time()
print("It has been {0} seconds since the loop started".format(end_time - start_time))
win.close()
当我计算每次迭代时,我发现我没有正确清除图形。迭代时间不断增加,我正在减慢数据采集速度。对于上面的示例,开头的迭代时间约为0.009 s
,而最后约为0.04 s
。因此,我有一个内存泄漏。
我知道matplotlib
我应该打电话给clf()
来正确清理情节。不幸的是,我对PyQtGraph并不熟悉,并认为clear = True
会解决这个问题。我相信它应该是可能的,因为PyQtGraph
是为这种用法而设计的。
我应该如何清除每次迭代的图表,以确保我不会减慢数据采集速度?
答案 0 :(得分:2)
当您在plotItem上调用plot时,您将创建一个新的plotDataItem。所有这些plotDataItems似乎都没有正确清理。您可以尝试仅使用一个plotDataItem并更新其内容。通过使用
执行此操作plot = p.plot(x, y, pen = "y")
然后在你的循环中
plot.setData(x, y_new)