Я пытаюсь применить функцию tapply, которую я написал, для фильтрации набора данных. Вот образец кадра данных (df) ниже, чтобы описать, что я пытаюсь сделать.
Я хочу сохранить в моем фрейме данных строки, в которых значение df $ Cumulative_Time наиболее близко к значению 14. Он должен делать это для каждого уровня фактора в df $ ID (сохраняйте строку, ближайшую к значению 14 для каждого фактора ID).
ID Date Results TimeDiff Cumulative_Time
A 7/10/2015 71 0 0
A 8/1/2015 45 20 20
A 8/22/2015 0 18 38
A 9/12/2015 79 17 55
A 10/13/2015 44 26 81
A 11/27/2015 98 37 118
B 7/3/2015 75 0 0
B 7/24/2015 63 18 18
B 8/21/2015 98 24 42
B 9/26/2015 70 30 72
C 8/15/2015 77 0 0
C 9/2/2015 69 15 15
C 9/4/2015 49 2 17
C 9/8/2015 88 2 19
C 9/12/2015 41 4 23
C 9/19/2015 35 6 29
C 10/10/2015 33 18 47
C 10/14/2015 31 3 50
D 7/2/2015 83 0 0
D 7/28/2015 82 22 22
D 8/27/2015 100 26 48
D 9/17/2015 19 17 65
D 10/8/2015 30 18 83
D 12/9/2015 96 51 134
D 1/6/2016 30 20 154
D 2/17/2016 32 36 190
D 3/19/2016 42 27 217
Я дошел до следующего:
spec_day = 14 # value I want to compare df$Cumulative_Time to
# applying function to calculate closest value to spec_day
tapply(df$Cumulative_Time, df$ID, function(x) which(abs(x - spec_day) == min(abs(x - spec_day))))
Вопрос: как мне включить эту функцию tapply как средство для фильтрации моего фрейма данных df? Правильно ли я подхожу к этой проблеме или есть какой-то более простой способ решить эту проблему, которого я не вижу? Любая помощь будет оценена по достоинству - спасибо!
split(df, df$ID)
, а затем сlapply
использовать свой подход для получения индексов, соответствующих определенному идентификаторуresult <- lapply(mysplit, FUN=function(df){df[which()...,]})
. Наконец, объедините все отфильтрованные данные сdo.call("rbind", result)
. Я бы посоветовал изучитьdata.table
вариантов - person Eric Lecoutre   schedule 31.05.2016