【问题标题】:Parallelizing OpenCV code using TBB使用 TBB 并行化 OpenCV 代码
【发布时间】:2012-06-14 15:04:39
【问题描述】:

我正在尝试使用 TBB 并行化一些用 OpenCV 编写的图像匹配代码。问题是根据我的匹配(在左图像中创建一个 5x5 窗口并在右像素中逐个像素地寻找匹配)本质上是一个只读操作,目前我正在尝试并行化内部循环(即在给定的高度。我分配不同的像素到不同的线程)。令我惊讶的是,cvSetImageROI 命令在并行完成时会中断。这是代码。

//Code below just carves out a window(5x5) at a current width which is to be matched
cvSetImageROI(leftImageROI, cvRect(curWidth - 2, 0, 5, 5));
IplImage* currentROI = cvCreateImage(cvSize(5, 5), leftImageROI->depth, leftImageROI->nChannels);
cvCopy(leftImageROI, currentROI);                   
cvResetImageROI(leftImageROI);

现在所有这些对我来说都是线程安全的,因为它们只读取图像。但是代码崩溃了。如果我在一开始就放了一个锁,虽然它可以工作。有人可以帮忙吗?

【问题讨论】:

    标签: opencv parallel-processing intel tbb


    【解决方案1】:

    setImageROI() 不是只读操作。显然,因为它正在改变图像的状态。即使它不会崩溃,您的某些复制操作也会在错误的 ROI 上运行(由不同的线程设置)。

    解决您的问题的方法是使用 OpenCV C++ API!

    你有一个 cv::Mat 而不是 IplImage。然后,您可以使用如下代码:

    // given: cv::Mat image
    // returns: cv::Mat dest
    cv::Rect roi(curWidth - 2, 0, 5, 5);
    cv::Mat local(image, roi);
    cv::Mat dest(...);
    local.copyTo(dest);
    

    现在为什么这是线程安全的?显然,原始图像的状态并没有改变。相反,ROI 被写入一个新的线程局部矩阵头。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-10-10
      • 1970-01-01
      • 2016-10-15
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多