Estoy de acuerdo con la respuesta de whuber, pero sólo quería añadir que el "+2" parte del código, que intenta cambiar el índice para que coincida con el pico recién encontrado en realidad 'overshoots' y debe ser "+1". por ejemplo, en el ejemplo que nos ocupa obtenemos:
> findPeaks(cc)
[1] 3 22 41 59 78 96
cuando resaltamos estos picos encontrados en un gráfico (negrita roja):
vemos que están constantemente a 1 punto del pico real.
en consecuencia
pks[x[pks - 1] - x[pks] > thresh]
debe ser pks[x[pks] - x[pks + 1] > thresh]
o pks[x[pks] - x[pks - 1] > thresh]
GRAN ACTUALIZACIÓN
siguiendo mi propia búsqueda para encontrar una función adecuada para encontrar picos escribí esto:
find_peaks <- function (x, m = 3){
shape <- diff(sign(diff(x, na.pad = FALSE)))
pks <- sapply(which(shape < 0), FUN = function(i){
z <- i - m + 1
z <- ifelse(z > 0, z, 1)
w <- i + m + 1
w <- ifelse(w < length(x), w, length(x))
if(all(x[c(z : i, (i + 2) : w)] <= x[i + 1])) return(i + 1) else return(numeric(0))
})
pks <- unlist(pks)
pks
}
un "pico" se define como un máximo local con m
puntos a cada lado de él que sean menores que él. por lo tanto, cuanto mayor sea el parámetro m
más estricto es el procedimiento de financiación de picos. así:
find_peaks(cc, m = 1)
[1] 2 21 40 58 77 95
la función también puede utilizarse para encontrar mínimos locales de cualquier vector secuencial x
vía find_peaks(-x)
.
Nota: ahora he puesto la función en gitHub por si alguien la necesita: https://github.com/stas-g/findPeaks