从 Pixel Patch OpenCV 获取方向直方图
Get Orientation Histogram from Pixel Patch OpenCV
我尝试从 CV 的 phase() 方法的结果中获取方向直方图。我尝试获取每个像素的圆形方向并将其除以 10。例如,对于 5x5 像素补丁,它看起来像这样:
{ 1 36 20 3 14
5 16 11 6 9
7 12 34 22 0
34 5 9 21 4
5 21 28 30 1}
我的问题是,我真的不知道如何扫描 Patch 的每个像素,然后获取它的 OrientationValue 来计算直方图的值。
我获取定位垫的代码如下所示:
Mat patch = src(Rect(px,py,15,15));
Mat Sx;
Sobel(patch, Sx, CV_32F, 1, 0, 3);
Mat Sy;
Sobel(patch, Sy, CV_32F, 0, 1, 3);
Mat mag, ori;
magnitude(Sx, Sy, mag);
phase(Sx, Sy, ori, true);
int** hist;
在变量 hist 中,我想通过另一种方法添加值。
我希望有人能理解我的想法并能帮助我。
我现在有一个计划,如何遍历给定的方向图像我使用文档中显示的循环 OpenCV Docu
for( i = 0; i < ori.rows; i++){
for( j = 0; j < ori.cols; j++){
cout << ori.at<uchar>(i,j) << endl;
}
}
但是像这样访问值不会给我方向值。有什么线索吗?
Ori
来自类型 CV_32F
而不是 CV_8U
,因此尝试 ori.at<float>(i,j)
ro 访问方向值
我尝试从 CV 的 phase() 方法的结果中获取方向直方图。我尝试获取每个像素的圆形方向并将其除以 10。例如,对于 5x5 像素补丁,它看起来像这样:
{ 1 36 20 3 14
5 16 11 6 9
7 12 34 22 0
34 5 9 21 4
5 21 28 30 1}
我的问题是,我真的不知道如何扫描 Patch 的每个像素,然后获取它的 OrientationValue 来计算直方图的值。
我获取定位垫的代码如下所示:
Mat patch = src(Rect(px,py,15,15));
Mat Sx;
Sobel(patch, Sx, CV_32F, 1, 0, 3);
Mat Sy;
Sobel(patch, Sy, CV_32F, 0, 1, 3);
Mat mag, ori;
magnitude(Sx, Sy, mag);
phase(Sx, Sy, ori, true);
int** hist;
在变量 hist 中,我想通过另一种方法添加值。 我希望有人能理解我的想法并能帮助我。
我现在有一个计划,如何遍历给定的方向图像我使用文档中显示的循环 OpenCV Docu
for( i = 0; i < ori.rows; i++){
for( j = 0; j < ori.cols; j++){
cout << ori.at<uchar>(i,j) << endl;
}
}
但是像这样访问值不会给我方向值。有什么线索吗?
Ori
来自类型 CV_32F
而不是 CV_8U
,因此尝试 ori.at<float>(i,j)
ro 访问方向值