OpenCV:为HIT-MISS创建一个方形结构元素

时间:2017-12-01 19:48:23

标签: c++ opencv opencv3.0

我想要一个函数在正方形内创建一个"正方形"结构元素,如:

    Mat explicit_kernel = (Mat_<int>(5, 5) <<
                -1, -1, -1, -1, -1,
                -1, 1, 1, 1, -1,
                -1, 1, 1, 1, -1,
                -1, 1, 1, 1, -1,
                - 1, -1, -1, -1, -1);

所以我试图制作一个丑陋的循环:

Mat generate_kernel(int size)
{
    if (size % 2 == 0)
    {
        printf("Input %i, not even, replaced by %i\n", size, size + 1);
        size++;

    }

    Mat out = Mat::ones(size + 2, size + 2, CV_8S);
    for (int i = 0; i <= size + 1; i++)
    {
        for (int j = 0; j <= size + 1; j++)
        {
            if (i == 0 || i == size - 1)
            {
                out.at<int>(i, j) = -1;
            }
            else
            {
                if (j == 0 || j == size - 1)
                {
                    out.at<int>(i, j) = -1;
                }
            }

        }
    }
    //Mat out = getStructuringElement(MORPH_RECT, Size(size, size), Point(-1, -1));
    return out;

}

但是我收到了#34;违规写入错误&#34;,无论如何我正在寻找一个更容易的想法, 代码的主要目的是在循环中创建结构元素: - 大小为1,大小为3的正方形...... 谢谢:))

2 个答案:

答案 0 :(得分:1)

我找到了一个解决方案,考虑到cv :: Mat是一个指针,并创建一个子矩阵

RegEx

答案 1 :(得分:1)

这可能已由cv::copyMakeBorder方法处理。

#include <iostream>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

Mat generate_kernel(int size, int outer_size=1)
{
    if (size % 2 == 0)
    {
        printf("Input %i, not even, replaced by %i\n", size, size + 1);
        size++;

    }
    Mat out = Mat::ones(size, size, CV_8S);
    copyMakeBorder(out,
                   out,
                   outer_size, // top
                   outer_size, // bottom
                   outer_size, // left
                   outer_size, // right
                   BORDER_CONSTANT,
                   Scalar(-1.0));
    return out;
}

int main(int argc, const char * argv[]) {
    cout << "Size 1: " << generate_kernel(1) << endl;
    cout << "Size 3: " << generate_kernel(3) << endl;
    cout << "Size 5: " << generate_kernel(5) << endl;
    return 0;
}

哪会产生以下......

Size 1: [ -1,  -1,  -1;
          -1,   1,  -1;
          -1,  -1,  -1]

Size 3: [ -1,  -1,  -1,  -1,  -1;
          -1,   1,   1,   1,  -1;
          -1,   1,   1,   1,  -1;
          -1,   1,   1,   1,  -1;
          -1,  -1,  -1,  -1,  -1]

Size 5: [ -1,  -1,  -1,  -1,  -1,  -1,  -1;
          -1,   1,   1,   1,   1,   1,  -1;
          -1,   1,   1,   1,   1,   1,  -1;
          -1,   1,   1,   1,   1,   1,  -1;
          -1,   1,   1,   1,   1,   1,  -1;
          -1,   1,   1,   1,   1,   1,  -1;
          -1,  -1,  -1,  -1,  -1,  -1,  -1]