opencv中的直线拟合函数 cvFitLine

本文介绍了OpenCV中的直线拟合函数cvFitLine,用于2D和3D点集的直线拟合。文章详细讲解了该函数的工作原理、参数设置,包括不同距离类型的定义,并给出了代码示例,帮助读者理解如何使用该函数进行直线拟合。
摘要由CSDN通过智能技术生成

opencv中 2D 或 3D 点集的直线拟合


代码参考:

http://hi.baidu.com/yuzaihuan/item/283d12f260513b43922af269

自己学习~

code:

#include "stdafx.h"
#include "cv.h"
#include "highgui.h"
#include <math.h>
int _tmain(int argc, _TCHAR* argv[])
{
	IplImage* img = cvCreateImage( cvSize( 500, 500 ), 8, 3 );
	CvRNG rng = cvRNG(-1); //cvRNG()跟一般的C语言srand()使用方法一样,要先给它一个种子,
	//但srand()用到的是unsigned int的32位种子范围,而cvRNG()用的是64位长整数种子。
	//初始化CvRNG资料结构,假如seed给0,它将会自动转成-1	cvRNG(64位种子)
	cvNamedWindow( "fitline", 1 );

	for(;;)
	{
		char key;
		int i;
		int	count = cvRandInt(&rng)%100 + 1; //产生1-100 之间的数
		int outliers = count/5; // 奇异点的个数。0--20 之间的数
		printf("count = %d", count);
		float a = cvRandReal(&rng)*200;  // 0~ 199 之间的浮点数 [cvRandReal 浮点型随机数并更新 RNG ,范围在 0..1 之间,不包括 。
		float b = cvRandReal(&rng)*40; //返回0 ~ 39之间的数
		float angle = cvRandReal(&rng)*CV_PI;  
		printf("count = %f", angle);
		float cos_a = cos(angle), sin_a = sin(angle);
		printf("cos_a = %f", cos_a);

		CvPoint pt1, pt2; //直线的两个端点
		CvPoint* points = (CvPoint*)malloc( count * sizeof(points[0])); //存放随机产生的点点,数目为count
		CvMat pointMat = cvMat( 1, count, CV
OpenCV提供了直线拟合函数fitLine,可以用于拟合多条直线。该函数的原型如下: void fitLine(InputArray points, OutputArray line, int distType, double param, double reps, double aeps); 其,points是输入的坐标点集合,line是输出的拟合直线的参数,distType是距离类型,param是距离参数,reps是拟合精度,aeps是角度精度。 要进行多条直线拟合,可以将多组坐标点分别传入fitLine函数进行拟合,得到对应的直线参数。可以使用std::vector<cv::Point>来存储每组坐标点,然后循环调用fitLine函数进行拟合。 以下是一个示例代码,用于拟合多条直线: std::vector<std::vector<cv::Point>> pointSets; // 存储多组坐标点 std::vector<cv::Vec4f> lines; // 存储拟合直线的参数 // 循环拟合每组坐标点 for (int i = 0; i < pointSets.size(); i++) { cv::Mat pointsMat(pointSets\[i\]); cv::Vec4f line; cv::fitLine(pointsMat, line, cv::DIST_L2, 0, 0.01, 0.01); lines.push_back(line); } 这样,lines就存储了拟合得到的多条直线的参数。每个直线的参数是一个cv::Vec4f,其前两个元素表示直线上的一个点,后两个元素表示直线的方向向量。 请注意,拟合直线的精度参数reps和aeps可以根据实际需求进行调整,以获得更好的拟合效果。 #### 引用[.reference_title] - *1* *2* *3* [OpenCV 学习(直线拟合)](https://blog.csdn.net/liyuanbhu/article/details/50193947)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值