0

如何应用观察向量来找到 R 中每个观察之间的局部最大值。我执行以下代码,但根据绘图结果应该只是两个局部最大值。我怎样才能在 R 中做到这一点?

    x = c(0.0000005, 0.1578947, 0.3157895, 0.4736842, 0.6315789, 0.7894737, 
      0.9473684, 1.1052632,1.2631579, 1.4210526, 1.5789474, 1.7368421,
      1.8947368, 2.0526316, 2.2105263, 2.3684211, 2.5263158 ,
      2.6842105, 2.8421053, 3.000000)     
    f = function(x) (x+1)*(x-2)*(x-1)*(x)*(x+1)*(x-2)*(x-3)
    plot(x, f(x), type="l")
     maximums = sapply(x, function(x)optimize(f, c(0, x), maximum = TRUE)$maximum)
4

1 回答 1

0

我不确定如何optimize为此目的应用该序列,但它肯定不会逐点应用。你可以想象制作一个多项式样条曲线,然后对其进行微分。微分的数值模拟是diff,局部最大值的条件是一阶导数小,二阶导数为负。这是一个满足这些条件的图(将颜色移动一个以解释向量的缩短diff

plot(x,f(x), 
     col=c("red","blue")[1+seq_along(x) %in%    # adding one to the logical values 0,1
                         c(0, which( diff(diff(f(x)))<0 & diff(f(x)) < 0.1))])
于 2013-10-14T06:14:16.893 回答