Согласованный метод добавления столбца id в элементы списка - PullRequest
0 голосов
/ 13 января 2020

У меня проблемы с использованием mapply для добавления столбцов идентификаторов в списки (в рамках более крупной функции).

Для большинства списков приведенный ниже код работает нормально ...

m1 <- matrix(data = 1:32, nrow = 8, ncol = 4)
m2 <- matrix(data = 1:8, nrow = 2, ncol = 4)
m3 <- matrix(data = 1:16, nrow = 4, ncol = 4)
m4 <- matrix(data = 1:4, nrow = 1, ncol = 4)
colnames(m1) <- colnames(m2) <- colnames(m3) <- colnames(m4) <- LETTERS[1:4]

a <- list(m1, m2, m3, m4)
mapply(cbind, a, m = 1:4)
# [[1]]
#      A  B  C  D m
# [1,] 1  9 17 25 1
# [2,] 2 10 18 26 1
# [3,] 3 11 19 27 1
# [4,] 4 12 20 28 1
# [5,] 5 13 21 29 1
# [6,] 6 14 22 30 1
# [7,] 7 15 23 31 1
# [8,] 8 16 24 32 1
# 
# [[2]]
#      A B C D m
# [1,] 1 3 5 7 2
# [2,] 2 4 6 8 2
# 
# [[3]]
#      A B  C  D m
# [1,] 1 5  9 13 3
# [2,] 2 6 10 14 3
# [3,] 3 7 11 15 3
# [4,] 4 8 12 16 3
# 
# [[4]]
#      A B C D m
# [1,] 1 2 3 4 4

, но когда у меня есть списки, содержащие матрицы одинаковых размеров, список больше не возвращается ...

a <- list(m2, m2, m2, m2)
mapply(cbind, a, m = 2)
#       [,1] [,2] [,3] [,4]
#  [1,]    1    1    1    1
#  [2,]    2    2    2    2
#  [3,]    3    3    3    3
#  [4,]    4    4    4    4
#  [5,]    5    5    5    5
#  [6,]    6    6    6    6
#  [7,]    7    7    7    7
#  [8,]    8    8    8    8
#  [9,]    2    2    2    2
# [10,]    2    2    2    2

Я не могу найти какое-либо объяснение тому, почему это происходит, или возможного обходного пути (где выводом будет список в формате, аналогичном первому примеру выше)?

1 Ответ

1 голос
/ 13 января 2020

Именно в этом разница между mapply и Map, mapply по умолчанию имеет аргумент simplify = TRUE, что означает

SIMPLIFY - логическая или символьная строка; попытаться свести результат к вектору, матрице или многомерному массиву; см. аргумент упрощения sapply.

Следовательно, в этом случае, чтобы получить вывод, такой же, как в первом примере, мы должны использовать Map

Map(cbind, a, m = 2)

#[[1]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[2]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[3]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2

#[[4]]
#     A B C D m
#[1,] 1 3 5 7 2
#[2,] 2 4 6 8 2
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...