【发布时间】:2020-07-24 03:21:35
【问题描述】:
一段时间后,我在 R 中编写了一个带有简单 for 循环的函数,有人向我提出了另一种方法来做同样的事情,但使用 dplyr。所以我尝试了一下,发现运行时间有很大差异我的脚本(- 1s !)。 我想知道所用时间的巨大差异从何而来。 dplyr 是否更加优化? dplyr 是否以某种加快进程的方式编译?我不知道
我原来的功能:
key.rythm <- function(key, data) {
## Un data frame vide pour recevoir les resultats
results <-
data.frame(
"down.time" = numeric(),
"duration" = numeric(),
"touche" = factor()
)
down.time <- NULL
## On est oblige de passer par une boucle pour parser ligne par ligne
for (i in 1:nrow(data)) {
if (data[i, "K.TOUCHE"] != key)
next
## Pour la bonne cle, si l'on rencontre un down, le stocker
##(ainsi, si l'on rencontre deux down de suite, sans up entre les deux,
##le premier sera effaee et seul le second comptera)
if (data$K.EVENEMENT[i] == "Key Down") {
down.time <- data$K.TEMPS[i]
} else {
## verifier si l'on a bien eu un down precedemment
if (is.null(down.time)) {
duration <- NA
down.time <- NA
} else{
## Calculer la duree entre down et up
duration <- data$K.TEMPS[i] - down.time
}
ligne <- c(down.time, duration)
results <- rbind (results, ligne)
## vider le down (en cas de deux up consecutifs, au cas ou)
down.time <- NULL
}
}
# 0 est considere comme FAUX on assigne que s'il y as des lignes
if (nrow(results)){
results$touche <- key
}
names (results) <- c ("down.time", "duration", "touche")
return(results)
}
和 dplyr 方式:
tmp<-group_by(filter (data,K.EVENEMENT == "Key Up"), K.TOUCHE)$K.TEMPS - group_by(filter (data,K.EVENEMENT == "Key Down"), K.TOUCHE)$K.TEMPS
【问题讨论】: