与Mat的R代表类似的函数

20 matlab r

我正在寻找一个rep与Matlab中R函数类似的函数.例如,rep我可以执行以下操作:

> rep(c(1,2,3),times=3)
[1] 1 2 3 1 2 3 1 2 3

> rep(c(1,2,3),each=3)
[1] 1 1 1 2 2 2 3 3 3
> 
Run Code Online (Sandbox Code Playgroud)

在matlab中有repmat函数,它完成了第一部分

>> repmat([1,2,3],1,3)

ans =

     1     2     3     1     2     3     1     2     3
Run Code Online (Sandbox Code Playgroud)

但不是第二部分(或者至少我不明白该怎么做).

有什么建议?

bcu*_*ing 12

您可以通过首先定义一个函数,如下所示,在R中重现rep函数的语法:

function [result]=rep(array, count)
matrix = repmat(array, count,1);
result = matrix(:);
Run Code Online (Sandbox Code Playgroud)

然后,您可以通过使用行或列向量调用来重现所需的行为:

>> rep([1 2 3],3)
ans =
 1     1     1     2     2     2     3     3     3

>> rep([1 2 3]',3)
ans =
 1     2     3     1     2     3     1     2     3
Run Code Online (Sandbox Code Playgroud)

注意我在第二次调用中使用了transpose(')运算符将输入数组作为列向量(3x1矩阵)传递.

我此基准我的笔记本电脑,以及用于与100000个元件的底板阵列重复100次,这是更快之间2至8倍,比使用上面的小区的选择,这取决于是否要在第一或第二布置.


Col*_*ers 8

好问题+1.完成此任务的简洁单线方法是通过Kronecker张量积,例如:

A = [1 2 3];
N = 3;
B = kron(A, ones(1, N));
Run Code Online (Sandbox Code Playgroud)

然后:

B =

     1     1     1     2     2     2     3     3     3
Run Code Online (Sandbox Code Playgroud)

更新: @丹提供了一个非常巧妙的解决办法,看起来比我的更有效的kron方法,所以请离开页面之前回答了:-)

更新: @bcumming还提供了一个很好的解决方案,当输入向量很大时,它应该非常好地扩展.


Dan*_*Dan 6

如果像我一样你不知道Kronecker张量产品是什么,你可能会对这个更直观(实际上我认为更快)的解决方案感兴趣:

c(ceil((1:length(c)*n)/n));
Run Code Online (Sandbox Code Playgroud)

所以我在这里用矢量索引来复制矩阵.例如,使用上面的两个案例,我们可以做到:

c = 1:3;
c([1 1 1 2 2 2 3 3 3]) %for each
c([1 2 3 1 2 3 1 2 3]) %for times
Run Code Online (Sandbox Code Playgroud)

所以问题是如何在没有你要求的功能的情况下制作矢量[1 2 3 1 2 3 1 2 3].所以我用我们需要的元素数量(即1:9)然后除以3并向上舍入(即ceil((1:9)/3)在命令行中尝试).

一些基准测试(我知道这些东西应该在循环中,所以这可能不是那么准确):

c = 1:3; n = 3;
tic; k = kron(c, ones(1, n)); toc; % 0.000208 seconds.
tic; a = c(ceil((1:length(c)*n)/n)); toc;  % 0.000025 seconds.
clear;
c = 1:1000000; n = 3;
tic; k = kron(c, ones(1, n)); toc; % 0.143747 seconds.
tic; a = c(ceil((1:length(c)*n)/n)); toc;  % 0.090956 seconds.
clear;
c = 1:10000; n = 1000;
tic; k = kron(c, ones(1, n)); toc; % 0.583336 seconds.
tic; a = c(ceil((1:length(c)*n)/n)); toc;  % 0.237878 seconds.
Run Code Online (Sandbox Code Playgroud)