Я считаю, что если вы заранее не знаете, являются ли все значения вектора положительными, то вам следует сделать что-то вроде приведенного ниже кода.
V <- c(2, 3, 4, 5, 6)
W <- c(-2, -3, -4, -5, -6)
X <- c(2, -3, 4, -5, 6)
all.neg <- function(x) -1*abs(x)
Давайте попробуем.
all.neg(V)
#[1] -2 -3 -4 -5 -6
all.neg(W)
#[1] -2 -3 -4 -5 -6
all.neg(X)
#[1] -2 -3 -4 -5 -6
Если вы хотите применить его к data.frame, сделайте это обычным способом.
dat <- data.frame(V, W, X)
dat[] <- lapply(dat, all.neg)
dat
# V W X
#1 -2 -2 -2
#2 -3 -3 -3
#3 -4 -4 -4
#4 -5 -5 -5
#5 -6 -6 -6