查看单个帖子
旧 2019-12-10, 20:30   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,008
声望力: 66
poster 正向着好的方向发展
帖子 考虑预先分配速度

我正在做以下

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的大小。

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



更多&回答...
poster 当前离线   回复时引用此帖