vec <- 1:4
n <- length(vec)
as.vector(rev(setNames(vec, n:1)[as.character(sequence(1:n))]))
# [1] 1 2 3 4 2 3 4 3 4 4
пару трюков здесь; as.vector
не нужно, он просто пропускает имена векторов.
Tyler <- function() do.call(rbind, mapply(compile, rows, nums, lst))
Julius <- function() as.vector(rev(setNames(vec, n:1)[as.character(sequence(1:n))]))
# Vector of length 3
# Unit: microseconds
# expr min lq median uq max neval
# Tyler() 144.183 148.383 151.649 155.382 2241.617 1000
# Julius() 73.724 76.058 80.724 82.590 276.236 1000
# Vector of length 1500
# Unit: seconds
# expr min lq median uq max neval
# Julius() 1.2181 1.270544 1.469416 1.506019 1.518471 10
# (list of 1500 diagonal matrices took too much memory, couldn't compare)
Редактировать.
JuliusTwo <- function() rev(vec[n + 1 - sequence(1:n)])
vec <- 1:3
n <- length(vec)
microbenchmark(Julius(), JuliusTwo(), times = 1000)
# Unit: microseconds
# expr min lq median uq max neval
# Julius() 72.326 75.125 76.525 78.392 259.905 1000
# JuliusTwo() 49.461 51.794 53.194 54.595 1950.450 1000
vec <- 1:1500
n <- length(vec)
microbenchmark(Julius(), JuliusTwo(), Henrik(x2), times = 10)
# Unit: milliseconds
# expr min lq median uq max neval
# Julius() 1497.9588 1499.9438 1547.660 1582.0843 1590.2048 10
# JuliusTwo() 157.0313 157.9193 177.682 200.7433 214.9415 10
# Henrik(x2) 4639.1891 6157.247 7178.9953 7350.8146 7640.8685 10
Matthew <- function() {m <- matrix(rep(vec, n), n);m[lower.tri(m, diag=TRUE)]}
microbenchmark(JuliusTwo(), Matthew(), Arun(vec), times = 100)
# Unit: milliseconds
# expr min lq median uq max neval
# JuliusTwo() 113.25630 121.69106 126.16566 150.42730 237.51304 100
# Matthew() 119.59806 126.87538 152.28000 157.42816 415.27231 100
# Arun(vec) 32.93695 37.78204 40.99725 43.19757 98.69791 100
Очень приятно. Я думал, что создание простого триплета может также работать довольно быстро, но это, похоже, быстро обманет. +1 –
@Julius +1. Кроме того, попробуйте следующее: «Arun <- function (x) x [sequence (n: 1) + rep.int (0: (n-1), n: 1)]' – Arun
@Arun, очень приятно, думал о улучшив мое решение в этом направлении, но не ожидал такого улучшения. – Julius