如何用OpenCV模仿Matlab的medfilt2?

时间:2012-09-21 17:45:25

标签: c++ matlab opencv

我有一个用Matlab编写的成像应用程序,需要使用OpenCV将其转换为C ++应用程序。但我似乎找不到用OpenCV模仿medfilt2的简单方法。

我尝试了MedianBlur,但它没有产生相同的结果。有人能给我任何线索吗?

1 个答案:

答案 0 :(得分:3)

在我看来,这link应该具有您所需要的。 但是,如果您想在n窗口指定m,则需要进行少量修改。

     //   Pick up window elements
     int k = 0;
     // Original: element window[9];
     element window[n_win*m_win];
     for (int j = m_win - 1; j < m_win; ++j)
        for (int i = n_win - 1; i < n_win; ++i)
           window[k++] = image[j * N + i];
     //   Order elements (only half of them)
     // make sure (n_win*m_win)/2 is odd :-)
     for (int j = 0; j < (n_win*m_win)/2; ++j)
     {
        //   Find position of minimum element
        int min = j;
        for (int l = j + 1; l < n_win*m_win; ++l)
        if (window[l] < window[min])
           min = l;
        //   Put found minimum element in its place
        const element temp = window[j];
        window[j] = window[min];
        window[min] = temp;
     }
     //   Get result - the middle element
     result[(m - 1) * (N - 2) + n - 1] = window[4];