如何加速opencv中的Frangi过滤(c ++)

时间:2017-03-03 13:26:05

标签: c++ opencv image-processing

我有这张图片:

enter image description here

我想通过使用Frangi过滤器检测此图像上的异常。我来的代码:Frangi filter。我将此参数用于frangi过滤器:

  // Manualy edited parameters of frangi filter.
#define DEFAULT_SIGMA_START 1
#define DEFAULT_SIGMA_END 3
#define DEFAULT_SIGMA_STEP 1
#define DEFAULT_BETA_ONE 1.6
#define DEFAULT_BETA_TWO 1.2
#define DEFAULT_BLACKWHITE true

异常检测工作正常。问题是计算速度。过滤时间为:7秒。在使用Frangi滤波器保持良好检测的同时,可以采用哪些可能的加速解决方案?

编辑1:花费最多时间的代码是用于frangi2d算法的循环:

for (float sigma = opts.sigma_start; sigma <= opts.sigma_end; sigma += opts.sigma_step) {
        //create 2D hessians
        Mat Dxx, Dyy, Dxy;
        frangi2d_hessian(src, Dxx, Dxy, Dyy, sigma);

        //correct for scale
        Dxx = Dxx*sigma*sigma;
        Dyy = Dyy*sigma*sigma;
        Dxy = Dxy*sigma*sigma;

        //calculate (abs sorted) eigenvalues and vectors
        Mat lambda1, lambda2, Ix, Iy;
        frangi2_eig2image(Dxx, Dxy, Dyy, lambda1, lambda2, Ix, Iy);

        //compute direction of the minor eigenvector
        Mat angles;
        phase(Ix, Iy, angles);
        ALLangles.push_back(angles);

        //compute some similarity measures
        lambda2.setTo(nextafterf(0, 1), lambda2 == 0);
        Mat Rb = lambda1.mul(1.0 / lambda2);
        Rb = Rb.mul(Rb);
        Mat S2 = lambda1.mul(lambda1) + lambda2.mul(lambda2);

        //compute output image
        Mat tmp1, tmp2;
        exp(-Rb / beta, tmp1);
        exp(-S2 / c, tmp2);

        Mat Ifiltered = tmp1.mul(Mat::ones(src.rows, src.cols, src.type()) - tmp2);
        if (opts.BlackWhite) {
            Ifiltered.setTo(0, lambda2 < 0);
        }
        else {
            Ifiltered.setTo(0, lambda2 > 0);
        }

        //store results
        ALLfiltered.push_back(Ifiltered);

        cout << "Interation done" << endl;
    }

1 个答案:

答案 0 :(得分:1)

您的图片有一个很大的黑色区域,您可以选择它的ROI,以便应用过滤器。

ROI选择可以基于预先检索寻找ROI的顶点的图像。也许它是针对您的应用程序修复的。也许您可以使用其他信息来选择投资回报率。

Rect region_of_interest = Rect(x, y, w, h);
Mat image_roi = image(region_of_interest);