在 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 帮助我修复了它。
我写了一个简单的 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 帮助我修复了它。