C++ 已知三点求圆心和半径 使用cv::mat
时间: 2023-09-19 19:11:44 浏览: 196
要求解三点确定的圆心和半径,可以使用向量代数方法。具体步骤如下:
1. 定义三个向量 a、b、c,分别表示三个点的坐标。
2. 计算向量 ab 和向量 ac 的中点,记为向量 m1 和向量 m2。
3. 计算向量 ab 和向量 ac 的垂线,分别记为向量 p1 和向量 p2。
4. 计算向量 m1 和向量 p1 的交点,记为向量 o1,向量 m2 和向量 p2 的交点,记为向量 o2。
5. 计算向量 o1 到向量 a 的距离,即为圆的半径 r。
6. 圆心坐标为向量 o1 的坐标。
使用 OpenCV 中的 cv::Mat 可以方便地进行向量运算。具体代码如下:
```c++
cv::Mat a = (cv::Mat_<double>(3, 1) << ax, ay, 1);
cv::Mat b = (cv::Mat_<double>(3, 1) << bx, by, 1);
cv::Mat c = (cv::Mat_<double>(3, 1) << cx, cy, 1);
cv::Mat ab = b - a;
cv::Mat ac = c - a;
cv::Mat m1 = (a + b) / 2;
cv::Mat m2 = (a + c) / 2;
cv::Mat p1 = cv::Mat_<double>({ {0, -1, m1.at<double>(1, 0) + ab.at<double>(0, 0) / ab.at<double>(1, 0) * (m1.at<double>(0, 0) - m1.at<double>(1, 0))} });
cv::Mat p2 = cv::Mat_<double>({ {0, -1, m2.at<double>(1, 0) + ac.at<double>(0, 0) / ac.at<double>(1, 0) * (m2.at<double>(0, 0) - m2.at<double>(1, 0))} });
cv::Mat o1 = p1.cross(m1);
cv::Mat o2 = p2.cross(m2);
double r = cv::norm(o1 - a);
cv::Mat center = o1 / o1.at<double>(2, 0);
```
其中 ax、ay、bx、by、cx、cy 分别为三个点的横纵坐标。
阅读全文