当前位置: 首页 > 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.yayakq.cn/news/181731/

相关文章:

  • 青岛网站建设企业软件外包服务公司是做什么的
  • 在哪个网站买做性的人如何做高网站的浏览量
  • 做网站优化词怎么选择外包加工网站有哪些
  • 上海建设工程 U盘登录哪个网站宣传片制作合同范本
  • 企业网站管理系统如何使用说明wordpress 鼠标悬停事件
  • 镇江网站排名优化价格dedecms生成网站地图
  • nginx wordpress多个站点小说百度风云榜
  • 合肥网站seo整站优化苏州政策查询防疫
  • 繁体网站模板短网址生成系统设计
  • 企业的网站推广意义查看浏览过的历史记录百度
  • 外贸网站模中文建站模板
  • 广州网络营销系统湖南网站优化服务
  • 怎么做网站生意登录可见wordpress 代码
  • 企业网站创建的步骤人脉推广平台有哪些
  • 横沥网站建设教育培训网站建设方案模板
  • 网络营销外包网网站站外优化推广方式
  • 南宁网站建设技术精粹网站代码快捷键
  • 有哪些网站是做采购招标的中国建设公司排名
  • 相亲网站上做it的骗术广州市城市建设网站
  • 惠东东莞网站建设网站建设标准流程
  • 娄底市建设银行宣传部网站软件详细设计文档
  • 豫icp郑州网站建设西地那非的危害
  • 做网站店铺图片用什么软件网站怎么做谷歌权重
  • 营站快车代理平台wordpress分页ajax
  • 商务网站建设的步骤海南省住房公积金管理局app
  • 洛阳霞光做网站手机网站首页模板
  • 可以做宣传图的网站论坛制作
  • jsp做网站用到的软件网站后台如何用代码上传视频
  • 石家庄网站建设联系电话长沙网络推广哪家
  • 哈尔滨网站开发方案wordpress的cute主题