У меня есть 2 функции, которые я использую внутри вызова mutate. Один выдает ожидаемые результаты для каждой строки, а другой повторяет одно и то же значение для всех строк:
library(dplyr)
df <- data.frame(X = rpois(5, 10), Y = rpois(5,10))
pv <- function(a, b) {
fisher.test(matrix(c(a, b, 10, 10), 2, 2),
alternative='greater')$p.value
}
div <- function(a, b) a/b
mutate(df, d = div(X,Y), p = pv(X, Y))
который производит что-то вроде:
X Y d p
1 9 15 0.6000000 0.4398077
2 8 7 1.1428571 0.4398077
3 9 14 0.6428571 0.4398077
4 11 15 0.7333333 0.4398077
5 11 7 1.5714286 0.4398077
т.е. столбец d
изменяется, а столбец v
является постоянным, и его значение фактически не соответствует значениям X
и Y
ни в одной из строк.
Я подозреваю, что это связано с NSE, но я не понимаю, как из того немногого, что мне удалось узнать об этом.
Что объясняет разное поведение div
и pv
? Как исправить pv
?