Tyo_ 2019-04-24 20:35 采纳率: 25%
浏览 1702
已结题

Python运行vibe算法过慢

现在在做毕设,有一部分要用到前景目标提取,我打算用VIBE算法来做,但是同样的算法,Python运行时初始化都要20-50s,我朋友用matlab基本就是1s内最多1s多一点就能完成初始化,虽然Python运行慢,但是也不至于慢这么多吧,而且理论上vibe算法的运行速度应该是比较快的,大佬们看一下是不是写的代码的问题。。。

def initial_background(I_gray, N):
    t1 = cv2.getTickCount()
    I_pad = np.pad(I_gray, 1, 'symmetric')#对称填充
    height = I_pad.shape[0]
    width = I_pad.shape[1]
    samples = np.zeros((height, width, N))
    t2 = cv2.getTickCount()
    time = (t2 - t1) * 1000 / cv2.getTickFrequency()
    print(time)
    for i in range(1, height - 1):
        for j in range(1, width - 1):
            for n in range(N):
                x, y = 0, 0
                while (x == 0 and y == 0):
                    x = np.random.randint(-1, 1)
                    y = np.random.randint(-1, 1)
                ri = i + x
                rj = j + y
                samples[i, j, n] = I_pad[ri, rj]
    t3 = cv2.getTickCount()
    time2 = (t3 - t1) * 1000 / cv2.getTickFrequency()
    print(time2)
    samples = samples[1:height - 1, 1:width - 1]
    return samples

上面是Python的初始化部分代码,大佬们帮忙看看这部分代码有哪些可以优化的。matlab代码我看不懂,也不知道该发哪个,第一次在CSDN上问问题,不知道会不会有人回答。。。

  • 写回答

3条回答 默认 最新

  • 超级马铃薯 2022-02-22 16:23
    关注

    我改写了一下,效果一样速度应该可以快100倍吧

    
        def __init_params(self, grayFrame):
            for k in range(self.__defaultNbSamples):
                c = np.random.randint(-1,2,size=(self.__Height,self.__Width))
                self.__samples[k] = np.maximum(grayFrame + c, 0)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月7日
  • 已采纳回答 3月15日

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog