当前位置: 首页 > news >正文

民治制作网站新乡网站优化公司

民治制作网站,新乡网站优化公司,各地网站备案,中企动力科技股份有限公司上海第一分公司在游戏开发和机器人路径规划乃至于现在比较火的自动驾驶中,我们常常需要确定两个物体是否发生碰撞,有一种通过闵可夫斯基差集法求是否相交的算法,下面将介绍一下 闵可夫斯基差集法的优势 闵可夫斯基差集法优势: 可以处理复杂的…

在游戏开发和机器人路径规划乃至于现在比较火的自动驾驶中,我们常常需要确定两个物体是否发生碰撞,有一种通过闵可夫斯基差集法求是否相交的算法,下面将介绍一下

闵可夫斯基差集法的优势

闵可夫斯基差集法优势:

  • 可以处理复杂的形状和多边形/多面体。
  • 提供精确的接触点和分离向量信息。

AABB的优势:

  • 不像AABB一样简单快速,只需要几次比较就可以完成相交测试
  • 可生成AABBTree,快速排除不可能相交的物体

可以看出AABB更快,闵可夫斯基差法更准,所以可以拿AABBTree缩小检测目标范围,最后精准检测的时候可以用闵可夫斯基差集法

闵可夫斯基差集法图形求交

有两个相交的图形A和B

在A中取一个点A1,和B中的所有点求差

将图形连接起来

再在A中取一个点A2,和B中的所有点求差

取A3,和B中的所有点求差

(其实在这里,原点出现在了生成的图形中,就可以终止循环了,我后面优化部分会提到)

取A4,和B中的所有点求差

连接所有结果

可以看到原点在闵可夫斯基差集的图形中,则成两个图形存相交情况

如果没有交点,也就不存在焦点了

测试代码

import numpy as npdef minkowski_difference(A, B):"""计算两个多边形A和B的闵可夫斯基差"""diff = []for a in A:for b in B:diff.append(a - b)return np.array(diff)def is_origin_inside(polygon):"""检查原点是否在多边形内部"""return true/falsedef polygons_collide(A, B):"""判断两个多边形是否碰撞"""# 计算闵可夫斯基差difference = minkowski_difference(A, B)# 检查原点是否在差集内return is_origin_inside(difference)# 示例:定义两个多边形的顶点
polygon_A = np.array([[0, 0], [2, 0], [2, 2], [0, 2]])  # 正方形
polygon_B = np.array([[1, 1], [3, 1], [3, 3], [1, 3]])  # 另一个正方形,与A相交# 检测碰撞
collision = polygons_collide(polygon_A, polygon_B)
print("Polygons collide:", collision)

优化:

①闵可夫斯基差的几何意义是所有可能从一个多边形内的任一点到另一个多边形内任一点的向量集合。而上面的方法生成的是一个点集,而不是这些点构成的实际几何形状(通常是凸包),因此,许多计算出来的点对于确定原点是否在闵可夫斯基差内部是没有必要的

我上边到A3遍历的时候,就已经知道相交了,就直接可以是否相交了,没必要再计算A4了

要避免不必要的计算,我们可以优化minkowski_difference函数,使其不生成完整的闵可夫斯基差集。我们可以在检测过程中动态地生成差异点,并且一旦发现原点位于闵可夫斯基差内,就可以立即返回结果,而不需要继续计算,简单优化下

import numpy as npdef minkowski_difference_check_origin(A, B):"""检查原点是否在两个多边形A和B的闵可夫斯基差内"""for a in A:for b in B:diff = a - bif is_origin_inside_single_point(diff):return Truereturn Falsedef is_origin_inside_single_point(point):"""简单检查单个点是否非常接近原点"""return true/falsedef polygons_collide(A, B):"""判断两个多边形是否碰撞"""# 动态检查原点是否在闵可夫斯基差内return minkowski_difference_check_origin(A, B)# 示例:定义两个多边形的顶点
polygon_A = np.array([[0, 0], [2, 0], [2, 2], [0, 2]])  # 正方形
polygon_B = np.array([[1, 1], [3, 1], [3, 3], [1, 3]])  # 另一个正方形,与A相交# 检测碰撞
collision = polygons_collide(polygon_A, polygon_B)
print("Polygons collide:", collision)

当然了,这个碰撞算法不是最佳的,有更加好的GJK算法,是一种优化后的技术,它巧妙地利用了闵可夫斯基差的概念,但在实际应用中避免了直接计算其所有点所带来的高昂代价

后面我将会更新GJK算法的文章

补充

注意是Minkowski Difference(闵可夫斯基差集)不是Minkowski Distance(闵可夫斯基距离),虽然都来源于数学家赫尔曼·闵可夫斯基的工作,但它们是两个不同的概念,应用领域也有所不同,这里注意区分

http://www.yidumall.com/news/82908.html

相关文章:

  • 东营专业网站建设公司电话seo免费入门教程
  • 弄一个电影网站怎么做网站制作设计
  • 云阿里云做网站济南专业seo推广公司
  • 网站服务器好营销的方法和技巧
  • 基于php网站开发环境河南郑州最新事件
  • 中心网站建设方法中国职业培训在线平台
  • 怎样向网站上传照片长沙网站优化效果
  • 东莞常平做网站公司直播营销的优势有哪些
  • 和嗲囡囡和做的网站全网营销老婆第一人
  • 山西百度公司做网站的昆明百度关键词优化
  • 一个小型网站开发成本网站搜索优化公司
  • 海北高端网站建设哪家好百度搜索资源平台提交
  • 旅游网站建设项目厦门seo网站优化
  • 视频网站怎么做可以播放电视剧网站做优化一开始怎么做
  • wordpress_子网站重命名推广赚钱app
  • 网站建设 秦皇岛公司泰州seo公司
  • 企业网络营销策划方案设计的例子seo系统培训哪家好
  • 在哪里购买域名seo外包资讯
  • 专门做有机食品的网站长沙关键词自然排名
  • 帝国cms做视频网站企业宣传网站
  • 网站多少页面合适本周时事新闻概要10条
  • 聊城做网站多少钱大数据培训班出来能就业吗
  • 外贸企业网站对外贸的重要性制作公司网站的公司
  • 企业网站定制公司百度在线下载
  • 网站策划岗位职责acca少女网课视频
  • 孝感建设银行网站营销方式有哪几种
  • 机票网站开发公司网站seo公司
  • 房地产开发公司的简介福州seo视频
  • c语言做的网站网络营销简介
  • 从做系统找不到以前的网站百度指数的使用