我的问题是:有没有办法在MATLAB / Octave中对这个操作进行矢量化?
y = %a (m x 1) vector, with every entry in [1, 10]
y2 = repmat(1 : 10, [m 1]);
for i = 1 : m
y2(i, :) = (y2(i, :) == y(i));
end
答案 0 :(得分:4)
bsxfun
是扩展和矢量化计算的好方法(如果它有用,它将执行多线程计算)。
m = 10;
y = randperm(m);
y2 = bsxfun(@eq,y,(1:m)')';