对于这个有点混乱的标题,我很抱歉,但我不确定如何更清楚地总结这一点。
我有两组 X、Y 数据,每组对应一个总体的总体值。它们是从原始数据中相当密集地采样的。我正在寻找的是一种为任何给定 Y 找到插值 X 的方法,该值介于我已经拥有的集合之间。
这张图更清楚地说明了这一点:
在这种情况下,红线来自对应于 100 的集合,黄线来自对应于 50 的集合。
我想说,假设这些集合对应于值的梯度(即使它们显然是由离散的 X、Y 测量值组成),我如何找到,比如说,如果 Y 是 500,X 会在哪里对于对应于值 75 的集合?
在此处的示例中,我希望我想要的点在此处附近:
我不需要这个函数过于花哨——它可以是数据点的简单线性插值。我只是想不通。
请注意,这两组的 X 和 Y 都不是完全重叠的。然而,说“这些集合共享的最近的 X 点在哪里”或“这些集合共享的最近的 Y 点在哪里”是相当微不足道的。
我在已知值之间使用了简单的插值(例如,为集合“50”和“100”找到对应 Ys 的 X,然后平均得到“75”),我最终得到如下所示的结果:
很明显我在这里做错了什么。显然,在这种情况下,对于所有那些 Y 高于“最低”集合的最大 Y 的情况,X (正确地)返回为 0。事情开始很好,但是当一个人开始接近最低设置的最大 Y 时,它开始变得混乱。
很容易看出为什么我的出错了。这是看待问题的另一种方式:
在“正确”版本中,X 应该是 250 左右。相反,我所做的基本上是平均 400 和 0,所以 X 是 200。在这种情况下,我该如何求解 X?我在想双线性插值可能是答案,但我无法找到任何东西来说明我将如何处理这类事情,因为它们似乎都是针对不同的问题而构建的。
感谢您的帮助。请注意,虽然我显然已经在 R 中绘制了上述数据以便于查看我在说什么,但最终的工作是在 Javascript 和 PHP 中。我不是在寻找重任;简单更好。