cv2 椭圆拟合_基于Opencv的最小二乘法拟合圆及椭圆

本文介绍了如何使用OpenCV库通过最小二乘法来拟合圆和椭圆。提供了两种不同的方法:一种利用LU分解解方程组,另一种采用QR分解。代码详细展示了如何计算和输出圆心坐标和半径,以及椭圆的参数。
摘要由CSDN通过智能技术生成

Opencv最小二乘拟合圆源代码:

Point3f LeastSquareFittingCircle(vectortemp_coordinates)//利用opencv solve函数的高斯消元算法(LU分解)解方程组

{

float x1 = 0;

float x2 = 0;

float x3 = 0;

float y1 = 0;

float y2 = 0;

float y3 = 0;

float x1y1 = 0;

float x1y2 = 0;

float x2y1 = 0;

int num;

vector::iterator k;

Point3f tempcircle;

num = temp_coordinates.size();

for (k = temp_coordinates.begin(); k != temp_coordinates.end(); k++)

{

x1 = x1 + (*k).x;

x2 = x2 + (*k).x * (*k).x;

x3 = x3 + (*k).x * (*k).x * (*k).x;

y1 = y1 + (*k).y;

y2 = y2 + (*k).y * (*k).y;

y3 = y3 + (*k).y * (*k).y * (*k).y;

x1y1 = x1y1 + (*k).x * (*k).y;

x1y2 = x1y2 + (*k).x * (*k).y * (*k).y;

x2y1 = x2y1 + (*k).x * (*k).x * (*k).y;

}

Mat left_matrix = (Mat_(3,3) << x2, x1y1, x1, x1y1, y2, y1, x1, y1, num);

cout << "left_matrix=" << left_matrix << endl;

Mat right_matrix = (Mat_(3, 1) << -(x3 + x1y2), -(x2y1 + y3), -(x2 + y2));

cout << "right_matrix=" << right_matrix << endl;

Mat solution(3,1,CV_32F);

solve(left_matrix, right_matrix, solution,CV_LU);

cout << "solution=" << solution << endl;

float a, b, c;

a = solution.at(0);

b = solution.at(1);

c = solution.at(2);

tempci

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值