第5篇 如何计算两个坐标点距离--opencv图像中的两个点

在地理和几何学中,大家经常需要计算两个坐标点之间的距离。此计算在实

际应用中非常常见,如导航系统、地图应用等。

  1. 欧氏距离--opencv图像中的两个点

欧氏距离是计算两个点之间最常见的方法之一。它是通过计算两个点在空间中

的直线距离来衡量的,可以将两点的坐标表示为

(x1, y1)和(x2, y2)。欧氏距离的计算公式如下:

distance = sqrt((x2 - x1)^2 + (y2 - y1)^2)

这个公式的基本思想是利用两点之间的直角三角形的斜边来计算距离。我们通

过将两个点的坐标代入公式来得到点之间的距离。

如:通过opencv获取到图像中的矩形轮廓,得到4个点,计算面积可找到最大的矩形

复制代码
ouble dis1 = Math.Sqrt( Math.Pow((box[1].X - box[0].X),2)+ Math.Pow((box[1].Y - box[0].Y), 2));
                    double dis2 = Math.Sqrt(Math.Pow((box[2].X - box[1].X), 2) + Math.Pow((box[2].Y - box[1].Y), 2));
                    double area1 = dis1 * dis2;
  1. 曼哈顿距离

曼哈顿距离是另一种常见的距离度量方法。是通过计算两个点在网格上水平

和垂直方向的距离之和来衡量的。可以将两点的坐标表示为

(x1, y1)和(x2, y2)。

曼哈顿距离的计算公式如下:

distance = |x2 - x1| + |y2 - y1|

这个公式的基本思想是将两个点之间的距离表示为在网格上行走的步数。我们

通过将两个点的坐标代入公式来计算两点之间的距离。

  1. 地球表面的距离

在计算地球上两个点之间的距离时,大家需要考虑地球的曲率。因为地球是一

个近似于椭球的球体,所以我们不能简单地使用平面几何中的直线距离公式。

为了计算地球表面上两点之间的距离,我们可以使用

Haversine

公式。这个公

式基于经纬度来计算两点之间的弧长,并将其转换为距离。Haversine公式的计算

公式如下:

a = sin^2((lat2 - lat1) / 2) + cos(lat1) * cos(lat2) * sin^2((lon2 -

lon1) / 2)

c = 2 * atan2(sqrt(a), sqrt(1-a))

distance = R * c

其中,lat1和lon1表示第一个点的纬度和经度,lat2和lon2表示第二个点的纬度和经度。R

是地球的半径,可以根据需要选择不同的单位(比如千米、英里

等)。

相关推荐
云资源服务商7 分钟前
阿里云无影AgentBay:开启AI智能体“自进化”时代的云端基础设施
人工智能·阿里云·云计算
一个不知名程序员www20 分钟前
算法学习入门---前缀和(C++)
c++·算法
SEO_juper26 分钟前
AI SEO实战:利用人工智能提升网站排名与流量的完整策略
人工智能·搜索引擎·百度·ai·seo·数字营销
暖阳之下26 分钟前
学习周报二十
人工智能·深度学习·学习
jackzhuoa33 分钟前
Rust API 设计的零成本抽象原则:从语言基石到工程实践
算法·rust
Doc.S36 分钟前
【保姆级教程】在AutoDL容器中部署EGO-Planner,实现无人机动态避障规划
人工智能·python·信息可视化·机器人
乌恩大侠37 分钟前
【东枫电子】AI-RAN 开发者套件,适用于6G科研与教学
人工智能·usrp
A_SKYLINE37 分钟前
低空无人机“一网统飞”深度解构:从技术内核到产业落地,重构低空经济操作系统
人工智能·重构·无人机·产品经理·低空经济
IT_陈寒38 分钟前
React性能优化:10个90%开发者不知道的useEffect正确使用姿势
前端·人工智能·后端
蒋星熠1 小时前
多模态技术深度探索:融合视觉与语言的AI新范式
人工智能·python·深度学习·机器学习·分类·数据挖掘·多分类