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

百度做网站多少钱一年外贸网站建设上海

百度做网站多少钱一年,外贸网站建设上海,中国建设部网站查询网,wordpress页面都在在游戏开发和机器人路径规划乃至于现在比较火的自动驾驶中,我们常常需要确定两个物体是否发生碰撞,有一种通过闵可夫斯基差集法求是否相交的算法,下面将介绍一下 闵可夫斯基差集法的优势 闵可夫斯基差集法优势: 可以处理复杂的…

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

闵可夫斯基差集法的优势

闵可夫斯基差集法优势:

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

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/590231/

相关文章:

  • 浙江交工宏途交通建设有限公司网站国内最佳网站建设设计
  • 网站网页设计培训机构广州软件开发工资
  • 做网站都能赚钱吗二手车网站系统
  • 网站虚拟主机空间1g多吗做视频网站收入
  • 21天网站建设实录wordpress源码安装
  • 新手做网站做那个赣州新闻联播今天回放
  • 和文化有关的吉网站建设模板南宁做网站价格
  • 西安网站建设云李空间如何安装wordpress
  • 网站续费问题怎么查网站的关键词
  • 做网站的猫腻买一个成品网站多少钱
  • 合肥网站推广胶带制作彩虹光影图片
  • 怎么自己做购物网站网址在线生成二维码
  • 河北网站建设就业考试担路网络科技有限公司的证书
  • 公司网站设计图片网站备案要营业执照原件吗
  • 如何做h5商城网站wordpress最近浏览器
  • 微网站 举例静态网站可以申请域名吗
  • 龙华区网站建设动漫设计属于什么大类
  • 网站建设背景朝阳登封seo推广
  • 有哪些外国网站国内可以登录的做网站编辑前景
  • 动态效果的网站建设为了选择合适的网络设计方案
  • 网站开发和设计实训做网站1008做网站 - 百度
  • 网站软文推广网站网页设计师通常是设计两套ui吗
  • 网站建设和维护采购协议书网站开发哪些专业
  • 重庆蒲公英网站建设公司WordPress文章内容彩色
  • 单一本地门户网站源码网站租金可以做办公费吗
  • 网站开发业内人士做视频营销哪个网站好
  • 住建部网站统计城乡建设统计信息系统登录看网站搜索什么关键词
  • 学生做网站的软件平面设计师务所
  • 项目网站建设行业公司网站
  • 网站做扫一扫平台的运营推广怎么做