Hola
Nuevamente necesito ayuda de ustedes, en muy pocas oportunidades
escribà una función, dirÃa que no tengo experiencia al respecto.
Escribo el código en R (copiar y pegar) con los comentarios y
descripción de los datos.
Esperando que se entienda ...
#######################################################
# Descricion de los datos (en orden de columnas)
# 5 Personas que realizan una actividad,
# por cada vez que se realiza se la numera
# cada actividad numerada es realizada a x dias desde
# la columna dias2 es generada para no tener blancos (vacÃos)
persona<-c(1,1,1,1,1,2,2,2,2,2,3,3,3,4,5,5)
numeracion <-c(1,2,3,4,5,1,2,3,4,5,1,2,3,1,1,2)
dias <-c(1,3,4,6,9,2,4,6,7,9,2,5,8,3,5,8)
dias2 <- c(1:length(dias))
datos <- data.frame(persona, numeracion, dias, dias2)
datos
# descripción de lo que deberÃa realizar
# observar la columna dias2
# cambia el primer valor y los ultimos (15 y 16)
datos$dias2[datos$dias2 < max(datos$dias2)] <- datos$dias2[-1]
datos$dias2[datos$dias2 == max(datos$dias2)] <- NA
datos
# al observar las columnas dÃas y dÃas2 me es fácil restar
# entre ambas columnas para obtener la diferencia de tiempo
###########
# Mi problema
# lo descripto anteriormente debe tomar el valor maximo de cada
# persona, no el maximo de todo el data.frame
# (un max por persona) y (un [-1] por persona)
# intente vosas como:
# probar <- do.call(rbind, by(datos, datos$persona, datos$dias,
function(x){...
# todos intentos que no fueron correctos
# ¿Me explico? ¿Ideas?
[[alternative HTML version deleted]]