[问题类型]:
两个满大的矩阵同时透过row来进行操作
用一个例子来说明我的问题
[软件熟悉度]:
新手
[问题叙述]:
A=[ 1 2 3 4 ] B=[ 1 2 3 4 ] A与B的column相同
[ 5 6 7 8 ] [ 5 6 7 8 ]
[ 9 10 11 12 ] [ 9 10 11 12 ]
[ 13 14 15 16 ] [ 13 14 15 16 ]
[ 17 18 19 20 ] [ 17 18 19 20 ]
[ 21 22 23 24 ]
[ 25 26 27 28 ]
[ 29 30 31 32 ]
我想透过类似apply的运算,将A与B两个矩阵的Column分别提出来运算,
运算内容是有点复杂,用上述例子来说明。
A* B*
以第一个column来说,提出来的分别是 [ 1 ] [ 1 ]
[ 5 ] [ 5 ]
[ 9 ] [ 9 ]
[ 13 ] [ 13 ]
[ 17 ] [ 17 ]
[ 21 ]
[ 25 ]
[ 29 ]
接着将A*每个元素与B*每个元素"乘积",也就是产生一个矩阵(向量也可以)如下
[ 1*1 1*5 1*9 1*13 1*17 1*21 1*25 1*29 ]
[ 5*1 5*5 5*9 5*13 5*17 5*21 5*25 5*29 ]
[ 9*1 9*5 9*9 9*13 9*17 9*21 9*25 9*29 ]
[ 13*1 13*5 13*9 13*13 13*17 13*21 13*25 13*29 ]
[ 17*1 17*5 17*9 17*13 17*17 17*21 17*25 17*29 ]
以此类推会产生 4 个矩阵(或向量),输出方式目前想到只有 list 比较方便。
由于我们两个矩阵A与B可能会有点大,因此希望可以稍微快一些的计算方法,
又希望程式码可读性可以高一点,让自己以后比较容易看懂(修改)。
~~~谢谢各位神人阅读~~~
[程式范例]:
我有尝试了一个方式,但我觉得可读性很低,
希望可以改的更简单易懂,速度更快一些。
我是用 指令outer 来做,以下程式码,矩阵大一点就要等一些时间了QQ
程式码贴于以下网址:
http://ideone.com/NmFGVT
[环境叙述]:
win10 + R_64
[关键字]:
outer apply mapply lapply