我有两个向量x
和w
。vectorw
是与 x 长度相同的权重数值向量。我们如何获得向量x
中差异很小的第一对元素的加权平均值(例如 tol= 1e-2),然后在下一次迭代中对下一对元素做同样的事情,直到没有它们的差异对小于 tol?例如,这些向量如下:
x = c(0.0001560653, 0.0001591889, 0.0001599698, 0.0001607507, 0.0001623125,
0.0001685597, 0.0002793819, 0.0006336307, 0.0092017241, 0.0092079042,
0.0266525118, 0.0266889564, 0.0454923285, 0.0455676525, 0.0457005450)
w = c(2.886814e+03, 1.565955e+04, 9.255762e-02, 7.353589e+02, 1.568933e+03,
5.108046e+05, 6.942338e+05, 4.912165e+04, 9.257674e+00, 3.609918e+02,
8.090436e-01, 1.072975e+00, 1.359145e+00, 9.828314e+00, 9.455688e+01)
我想找出哪一对元素的x
差异最小,找到这对元素后,得到加权平均平均值。我尝试了这段代码,但这个代码没有给我结果。我怎样才能找到索引min(diff(x))
并检查它是否小于 tol?
> min(diff(x))
> which(min(diff(x)) < 1e-2)