【opencv】几何变换——极坐标变换(8 对数极坐标函数logPolar)

8 对数极坐标函数logPolar(OpenCV 3.X新特性)

void logPolar(src,dst,Point2f center,double M,intflags)
  • src:输入图像矩阵
  • dst:输出图像矩阵
  • center:极坐标变换中心
  • M:系数,该值大一些效果会更好
  • flags:WARP_FILL_OUTLIERS:笛卡尔转对数极坐标;WARP_INVERSE_MAP:对数极坐标转笛卡尔;

笛卡尔转对数极坐标

在这里插入图片描述

对数极坐标转笛卡尔

【opencv】几何变换——极坐标变换(8 对数极坐标函数logPolar)_第1张图片

  • 显然M值越小,得到的r’方向上的压缩越大,在图像表现为r’方向上的信息越来越少,因此将M设置大一些效果更好。
#include
using namespace std;
#include
#include
#include
using namespace cv;

int main()
{
	//读入图像
	Mat src = imread("C://Users//lsh//Desktop//OpenCV算法精解-测试图片//第3章//img2.jpg", IMREAD_GRAYSCALE);
	if (!src.data)
		return -1;
	//对数极坐标变换
	Mat dst;
	Point2f center(508, 503);
	float M = 100;//M取值越大,在水平方向得到的值越多
	logPolar(src, dst, center, M, WARP_FILL_OUTLIERS);//笛卡尔转对数极坐标
	
	//显示原图和变换后的结果
	imshow("原图", src);
	imshow("对数极坐标变换", dst);
	waitKey(0);
	return 0;
}

你可能感兴趣的:(opencv,计算机视觉,图像处理)