Я пытаюсь применить функцию к каждой строке или столбцу матрицы, но мне нужно передать другое значение аргумента для каждой строки.
Я думал, что знаком с lapply, mapply и т. Д. Но, вероятно, этого недостаточно.
В качестве простого примера:
> a<-matrix(1:100,ncol=10);
> a
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10]
[1,] 1 11 21 31 41 51 61 71 81 91
[2,] 2 12 22 32 42 52 62 72 82 92
[3,] 3 13 23 33 43 53 63 73 83 93
[4,] 4 14 24 34 44 54 64 74 84 94
[5,] 5 15 25 35 45 55 65 75 85 95
[6,] 6 16 26 36 46 56 66 76 86 96
[7,] 7 17 27 37 47 57 67 77 87 97
[8,] 8 18 28 38 48 58 68 78 88 98
[9,] 9 19 29 39 49 59 69 79 89 99
[10,] 10 20 30 40 50 60 70 80 90 100
Скажем, я хочу применить функцию к каждой строке, я бы сделал:
apply(a, 1, myFunction);
Однако моя функция принимает аргумент, поэтому:
apply(a, 1, myFunction, myArgument);
Но если я хочу, чтобы мой аргумент принимал разные значения для каждой строки, я не могу найти правильный способ сделать это. Если я определю myArgument с несколькими значениями, очевидно, что весь вектор будет передаваться при каждом вызове myFunction.
Я думаю, что мне понадобится некий гибрид между применением и многовариантным отображением. Имеет ли это смысл ?
Один из `` грязных '' способов достижения моей цели - разбить матрицу по строкам (или столбцам), использовать mapply в результирующем списке и объединить результат обратно в матрицу:
do.call(rbind, Map(myFunction, split(a,row(a)), as.list(myArgument)));
Я посмотрел на развертку, агрегирование, все варианты применения *, но я не нашел идеального соответствия моим потребностям. Я пропустил это?
Спасибо за помощь.