登录论坛

查看完整版本 : 考虑预先分配速度


poster
2019-12-10, 20:30
我正在做以下

for i = 1:m, index = 0; for j = 1:n, index = index+values(i,j)*2^(j-1); if (j==1) symbol_chip = chip_values(index+1,:); else symbol_chip = [symbol_chip chip_values(index+1,:)]; end end end 它告诉我以下内容:

symbol_chip可能正在循环内增长。考虑预先分配速度。

有任何想法吗?



回答:

是。每次走动时, elseif块都会调整symbol_chip大小,这很昂贵。取而代之的是,重写代码,以使您拥有(例如) symbol_chip = zeros(max_size, 1);在循环之前。然后,更改内容,但不要更改symbol_chip的大小。

您需要稍作更改,但是这样做会更快。如果您对当前的速度不满意,请不要进行任何更改!



更多&回答... (https://stackoverflow.com/questions/2151636)