是否有更准确的方法来使用 Sphero API 检测球对球的碰撞?
Posted
技术标签:
【中文标题】是否有更准确的方法来使用 Sphero API 检测球对球的碰撞?【英文标题】:Is there a more accurate way to detect ball to ball collisions with Sphero API? 【发布时间】:2013-03-05 21:30:49 【问题描述】:我正在为 sphero(机器人球)编写游戏(他们的论坛有问题,似乎无法提问)。我正在尝试为 2 名或更多球员进行球对球碰撞检测。
首先,他们在这里给出了一个示例: https://github.com/orbotix/Sphero-ios-SDK/tree/master/samples/CollisionDetection
他们提供的阈值太敏感了,在木地板上它一直触发。暂时忘记这一点,我必须使用两个设备的影响时间戳来查看它们是否大致同时触发了碰撞。
我的问题是在减去时间戳时,在某些情况下我会得到非常广泛的变化,我认为开始时的差异很长。我存储了几个时间戳,所以我不会错过正确的一个,我尝试使用死时间来看看降低它是否会有所帮助。
最常见的减去 2 个 NSTimeIntervals 我得到 0.68 和 0.72 之间的差异(我预计会有 0.01 级反应)。所以我检查差异是否低于 0.72,连续 3 次我在 0.72 和 0.73 之间,有几次我得到 1.5、2.6、1.1 甚至 3.8。
它似乎并不可靠。文档说这次来自 iPhone 参考。两台设备会自动同步以获取时间,因此它们尽可能靠近。
有没有人试过这个并想出一个可靠的解决方案,而不涉及保持一个球静止?
【问题讨论】:
【参考方案1】:当我开始担任 Sphero 的制造商 Orbotix 的开发人员时,我对球对球碰撞的主题进行了大量研究。
这是一个非常复杂的问题。我最接近完成这项工作(对于受感染的僵尸研究游戏)是检测哪个球击中哪个球的准确率约为 80%,样本大小为 3。你放入游戏中的球越多,准确率越低变得。因此,我们决定通过让一个球在易受攻击之前停止移动来消除这个问题,就像在 Sphero TAG 中一样。
有几个因素会限制此功能,您似乎已经发现了它们。我认为最大的问题是碰撞检测在球行驶时表现不佳。尤其是在粗糙的表面上或当球做出快速的急速运动时。再加上死区时间,仅此一项就会导致专业问题。
我能够将碰撞时间戳平均控制在 50 毫秒以内。您是否考虑在手机之间传输数据包时的 wifi 延迟?
解决方案是您可能不想听到的,但您应该调整您的游戏玩法以在碰撞检测功能范围内工作。也就是说,当可以接触到球时,球的行驶速度非常慢,甚至像 TAG 一样停下来。问问自己,如果没有球对球的碰撞,我怎样才能让这个变得有趣?
【讨论】:
wifi 延迟?通过阅读文档,我了解到影响时间戳是由 sphero 创建的,使用手机时间作为参考,因此我可以忽略延迟,因为它是事件发生时间的记录,而不是接收数据包的时间。是的,我玩过 sphero tag,我真的不想这样做,因为我真的不喜欢它,我想我只能放弃它。感谢您的建议,为我节省了很多时间【参考方案2】:我只想说,首先,我们将这里的开发者支持论坛移至 ***,这就是为什么你不能在论坛上发帖的原因。所以,Simon,你做对了,来到 ***,你应该感到自豪。
我们只是将论坛更改为重定向到这里,而不是让人们感到困惑。
【讨论】:
【参考方案3】:时间戳由 Sphero 生成。但它们只有在您使用 Poll Packet Times 命令来生成延迟和偏移值时才有意义。请参考 API 命令文档中的 DID 00h、CID 50h。
话虽如此,碰撞检测是一项不断发展的技术。我们在机器人内部实时滑动数据窗口上采用了巧妙编码的 DFT 频率变换。这些参数允许调整到您正在运行的表面;没有通用设置。如果您获得太多误报,请进行实验。如果您有改进算法的想法,请直接联系我们,也许我们可以将其作为一种新的过滤方法。我们总是乐于接受聪明的想法!
【讨论】:
感谢您的帮助,但我正在计划一场多球比赛,但实际上,除非每个球内都有 NFC 之类的东西,否则我认为效果并不好。这样,如果有 8 个以上的球在你周围漫游,就会有时间戳和哪个球击中你的唯一 ID,但这可能无法实现【参考方案4】:您可以在游戏开始时同步每个 Sphero 的内部计时器。这些可以与每个主机电话内的同步计时器进行匹配。时钟可能不同,但一毫秒就是一毫秒。您还可以降低碰撞检测的阈值,从而使“事件”(损坏、感染等)只有在“攻击”Sphero 以一定速度移动时才会发生。或其变体。
【讨论】:
以上是关于是否有更准确的方法来使用 Sphero API 检测球对球的碰撞?的主要内容,如果未能解决你的问题,请参考以下文章