Это продолжение предыдущего вопроса: Применить функцию к каждой записи одной таблицы к каждой записи другой
У меня есть следующие таблицы loss.tib
и bandstib
и функцияbandedlossfn
:
library(tidyverse)
set.seed(1)
n <- 5
loss.tib <- tibble(lossid = seq(n),
loss = rbeta(n, 1, 10) * 100)
bandstib <- tibble(bandid = seq(4),
start = seq(0, 75, by = 25),
end = seq(25, 100, by = 25))
bandedlossfn <- function(loss, start, end) {
pmin(end - start, pmax(0, loss - start))
}
Эту функцию можно применить к loss.tib
, используя bandstib
в качестве аргументов:
loss.tib %>%
mutate(
result = map(
loss, ~ tibble(result = bandedlossfn(.x, bandstib$start,
bandstib$end))
)
) %>% unnest
Однако я хотел бы добавить индекс вКарта выглядит следующим образом:
loss.tib %>%
mutate(
result = map(
loss, ~ tibble(result = bandedlossfn(.x, bandstib$start,
bandstib$end)) %>%
mutate(bandid2 = row_number())
)
) %>% unnest
Но, похоже, она не работает так, как задумано.Я также хочу добавить filter(!near(result,0))
в функцию карты для эффективного управления памятью.
Ожидаемый результат:
lossid loss bandid result
1 21.6691088 1 21.6691088
2 6.9390647 1 6.9390647
3 0.5822383 1 0.5822383
4 5.5671643 1 5.5671643
5 27.8237244 1 25.0000000
5 27.8237244 2 2.8237244
Спасибо.