在 oct 文件中将八度矩阵转换为 cv::Mat

convert octave Matrix to cv::Mat in oct file

我写了一个简单的 Oct 文件来包装 OpenCV 函数。这是我的代码:-

#include <octave/oct.h>
#include <opencv2/imgproc.hpp>

DEFUN_DLD (cornerHarris, args,  , "Harris Corner Detector")
{
  // Processing arguments
  if(args.length()<4){
    print_usage();  
  }
  Matrix octInMat = args(0).matrix_value();
  int blockSize = args(1).int_value();
  int kSize = args(2).int_value();
  double k = args(3).double_value();
  int borderType = args(4).int_value();
  
  // Dimentions
  dim_vector dims = octInMat.dims();
  int h = dims.elem(0);
  int w = dims.elem(1);
    
  // OpenCV Matrix
  cv::Mat cvInMat = cv::Mat::zeros(h,w, CV_8U);
  cv::Mat cvOutMat = cv::Mat::zeros(h,w, CV_32FC1);
  
  // Converting Octave Matrix to OpenCV Matrix
  for (int r=0;r<h;r++)
  {
       for(int s=0;s<w;s++)
       {
           cvInMat.at<int>(r,s) = octInMat(r,s);
       }
  }
 
  cv::cornerHarris( cvInMat, cvOutMat, blockSize, kSize, k, borderType );
  
  // Converting OpenCV Matrix to Octave Matrix
  Matrix octOutMat = Matrix(dim_vector(h,w));
  for (int r=0;r<h;r++)
  {
       for(int s=0;s<w;s++)
       {
           octOutMat(r,s) = cvOutMat.at<double>(r,s);
       }
  }

  return octave_value(octOutMat);
}

但是当 w 变量的值增加时,我遇到了分段错误。有没有循环转换矩阵的捷径?或者有什么方法可以解决分段错误吗?

文档:-

我通过在我的代码中逐行注释来解决这个问题。由于类型转换问题,此行出现此问题。

cvInMat.at<int>(r,s) = octInMat(r,s);

我更改如下。

cvInMat.at<uchar>(r,s) = (uchar)octInMat(r,s);

answer 帮助我修复了它。