Я підтримую пакет, на який покладаються неодноразові дзвінки deparse(control = c("keepNA", "keepInteger"))
. control
завжди однакова, і вираз змінюється. deparse()
здається, витрачає багато часу на повторне тлумачення одного і того ж набору варіантів .deparseOpts()
.
microbenchmark::microbenchmark(
a = deparse(identity, control = c("keepNA", "keepInteger")),
b = .deparseOpts(c("keepNA", "keepInteger"))
)
# Unit: microseconds
# expr min lq mean median uq max neval
# a 7.2 7.4 8.020 7.5 7.6 55.1 100
# b 3.0 3.2 3.387 3.4 3.5 6.0 100
У деяких системах надлишкові .deparseOpts()
дзвінки фактично займають більшу частину часу виконання deparse()
( графік полум'я тут ).
Я дуже хотів би просто зателефонувати .deparseOpts()
один раз, а потім надати цифровий код deparse()
, але це видається неможливим без виклику .Internal()
або виклику коду С безпосередньо, жоден з яких не є оптимальним з точки зору розробки пакету.
deparse
# function (expr, width.cutoff = 60L, backtick = mode(expr) %in%
# c("call", "expression", "(", "function"),
# control = c("keepNA", "keepInteger", "niceNames",
# "showAttributes"), nlines = -1L)
# .Internal(deparse(expr, width.cutoff, backtick, .deparseOpts(control),
# nlines))
# <bytecode: 0x0000000006ac27b8>
# <environment: namespace:base>
Чи є зручне рішення?