我正在使用 Python 2.7.4 创建一个简单的绿屏应用程序,但结果很慢。我目前正在使用 PIL 1.1.7 加载和迭代图像,并看到从旧的 getpixel() 到新的 load() 和像素访问对象索引的巨大加速变化。然而,对于分辨率约为 720p 的图像,以下循环仍然需要大约 2.5 秒的时间来运行:
def colorclose(Cb_p, Cr_p, Cb_key, Cr_key, tola, tolb):
temp = math.sqrt((Cb_key-Cb_p)**2+(Cr_key-Cr_p)**2)
if temp < tola:
return 0.0
else:
if temp < tolb:
return (temp-tola)/(tolb-tola)
else:
return 1.0
……
for x in range(width):
for y in range(height):
Y, cb, cr = fg_cbcr_list[x, y]
mask = colorclose(cb, cr, cb_key, cr_key, tola, tolb)
mask = 1 - mask
bgr, bgg, bgb = bg_list[x,y]
fgr, fgg, fgb = fg_list[x,y]
pixels[x,y] = (
(int)(fgr - mask*key_color[0] + mask*bgr),
(int)(fgg - mask*key_color[1] + mask*bgg),
(int)(fgb - mask*key_color[2] + mask*bgb))
我在这里做了什么效率非常低的事情,让它运行得这么慢吗?我见过类似的、更简单的例子,例如循环被布尔矩阵替换,但在这种情况下,我看不到替换循环的方法。
像素 [x,y] 分配似乎花费了最多的时间,但对 Python 不太了解,我不确定是否有更有效的方法来做到这一点。
任何帮助,将不胜感激。