- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 3d 空间中有两个 2d 圆(由中心、法线和半径定义),我试图提出一对点,它是一组最接近的点对之一。我知道有从 1 到无限数量的点对,我只需要一个匹配对。
有没有一种简单的方法可以做到这一点?精度不是必需的。两个圆的半径相同,非零值。
如果背景有帮助,我的整体算法采用空间中的 NURBS 曲线并沿曲线挤出 2d 多边形,产生变形的圆柱体。我只是沿曲线采样几个点。每个圆的法线是 NURBS 曲线的切线,我试图弄清楚如何对齐相邻的样本,所以我不会得到奇怪的扭曲。似乎应该对齐相邻样本上最近的点。
感谢这里的所有回复......项目的这一部分有点延迟,这就是为什么我还没有测试所有答案。当我再次开始处理这个问题时,我一定会在这里扔一些图片并标记一个答案。
最佳答案
您真正要计算的是一对点,该点对最小化位于 3 维 2 个不同圆上的点之间的距离。您应该采用的方法来找到精确解(就像在几乎所有优化问题中一样)是将距离表示为所有可能点的函数,并取其相对于自变量的导数并将结果表达式设置为 0 . 由于您有 2 个圆,因此您将有 2 个自变量(即一个圆上的一个点和另一个圆上的一个点的角度)。一旦你解决了最小化方程,你也会在圆上找到满足你的约束的点。 (基本上,您会在圆圈上找到您要查找的点对的角度。)
我找到了一个 paper在线(在 this site 上)严格执行计算,但最终结果是求解 8 阶多项式方程。您可能会尝试简化方程式并提出满足您需求的不太精确的解决方案。
还有一个paper声称有一个更快的算法来找到 3d 中两个圆之间的距离;但是,我无法查看内容,因此无法判断它是否也提供了满足该条件的点对。
更新:重新阅读您的问题后,我看到即使您要求一种在 3 维的两个圆上找到最接近的一对点的方法,我认为,您应该更加注意您所使用的 NURBS 曲线的属性试图沿挤出 2D 多边形。您提到曲线上给定点的圆的方向由该点的切向量指定。然而,3D 曲线不仅仅是切线向量;有正常 (或 曲率 )向量指向曲线在给定点的曲率中心,然后是 扭力向量基本上指定了曲线从切线和法线向量给定的平面的“提升”量。所有这些都定义了一个(所谓的)Frenet 框架。您可以在 Wikipedia article 上阅读更多关于这些内容的信息。 .
我的怀疑是,您可以通过连接每个位于底层 3D 曲线的法向量方向的连续圆的点来实现您想要的效果。这样,只有当曲线实际扭曲时才会扭曲,即当扭转矢量非零且法线矢量也在改变方向时。在其他情况下,这应该可以满足您的实际需要。
您可能不需要在连续的圆上寻找最近点的矫枉过正。
关于math - 如何计算两个 3d 圆上的一对最近点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1324051/
我需要获取过去 24 小时的记录,但不能像这样按小时分组: SELECT HOUR(CompDate) AS hour, COUNT(1) AS action FROM mytable WHERE (
我们有一个自动完成列表,当您向某人发送电子邮件时会填充该列表,这一切都很好,直到列表变得非常大,您需要输入越来越多的地址才能找到您想要的地址, 这违背了自动完成的目的 我在想应该添加一些逻辑,以便自动
我在 android 的锁屏上工作我们如何禁用导航软按钮,已经尝试了所有方法,systemoverlay但它不起作用,在按下主页按钮时它会终止服务和 Activity 。 最佳答案 后退按钮可以通过覆
我有一个报告创建时间为 2016-05-30,现在我需要从报告时间开始的最后 7 天。我怎样才能使用时刻? report_create_time = moment('2016-05-30').form
我想找出向量中最接近的三个数字。 就像是 v = c(10,23,25,26,38,50) c = findClosest(v,3) c 23 25 26 我试过 sort(colSums(as.ma
考虑以下表结构: id speed 1 100 2 200 3 300 4 400 5 500 考虑以下查询:"SELECT * FROM records WHERE
我正在开发一个依赖 YouTube 直播和实时聊天(也来自 YouTube)的网络应用。事情进展顺利,突然嵌入的聊天功能无法在移动设备上运行。 我试图在我这边找到一个错误或一些无效的配置,但我找不到。
我正在制作一个 React Native 应用程序,它有一个安全部分,用户必须在其中输入密码才能解锁 protected 内容。问题是,当用户在锁定该部分之前切换到另一个应用程序时,将生成屏幕截图以及
我有一条 SQL 语句 (SQL Server Management Studio),我通过仪表板软件将数据传递到 where 语句中。用户可以选择年份(2013 年或现在的 2014 年)和月份(作
我有一个脚本可以添加一组行,使您能够在 SharePoint 列表表单中捕获其他访问者的信息。我有两个 anchor 标记,一个用于添加,另一个用于删除。当我添加一个新的访问者时它有效,当我删除访问者
我正在学习斯坦福 iOS 类(class),我有一个问题,我认为与最近的更新有关。这是代码部分: func evaluate(ops: [Op]) -> (result: Double?,remain
我注意到我的应用有一个奇怪的行为。每当我按下主页按钮时,我的应用程序就会被杀死。我没有在应用程序堆栈中看到该应用程序。我可以看到之前启动的其他应用程序。最初我怀疑 android:launchMode
我需要获取过去 7 天内的所有付费和临时条目,但我总是收到所有退回的内容。我不确定我做错了什么,我已经阅读了这里的很多帖子,但无法理解它是什么。 MySQL 5.6(如果它与我一直在做的事情有什么不同
我的表有一列以 mysql time() 格式格式化。 当它是一个值分配给名为 $preRemainOt 的 php 变量时我想重新安排到最近的 15 分钟 function roundTime($w
我想获取过去 7 天内每天每个产品的最后时间戳。数据库中有数千条记录。我怎样才能通过查询来做到这一点。大约有 25 种不同的产品,每种产品每天大约有 50 个时间戳。 表:构建数据 'Timesta
我现在的代码正在从 SQL 中获取移动应用程序中的数据,首先添加显示,我需要将其设置为在我的 Android 应用程序中显示最后添加的第一个。我有如下所示的 api 代码,最新的是根据我的要求显示的,
我有一张 table ,说 table 的描述为: | ID | SNO | c1 | c2 | c3 | ___________________________________ |
我有两个大小相等的向量,例如 A=[2.29 2.56 2.77 2.90 2.05] and B=[2.34 2.62 2.67 2.44 2.52]. 我有兴趣在两个相同大小的向量 A 和 B 中
之前,我在这里发布了一个问题,询问有关如何从驱动器读取和写入数据的建议,而不是通过像“aaa.txt”这样的文件标签,而只是扇区..我被建议尝试阅读和写作....但新问题出现了……毛茸茸的参数 int
我想删除在给定时间段内未登录的用户,但我稍后会根据结果选择时间段。 所以我需要报告,其中我将收到过去 1 个月、2 个月...... n 个月内未登录的用户数量。 我不太清楚如何在单个 mysql 查
我是一名优秀的程序员,十分优秀!