![]() |
考虑预先分配速度
我正在做以下
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 它告诉我以下内容: [INDENT] symbol_chip可能正在循环内增长。考虑预先分配速度。 [/INDENT]有任何想法吗? [B]回答:[/B] 是。每次走动时, elseif块都会调整symbol_chip大小,这很昂贵。取而代之的是,重写代码,以使您拥有(例如) symbol_chip = zeros(max_size, 1);在循环之前。然后,更改内容,但不要更改symbol_chip的大小。 您需要稍作更改,但是这样做会更快。如果您对当前的速度不满意,请不要进行任何更改! [url=https://stackoverflow.com/questions/2151636]更多&回答...[/url] |
所有时间均为北京时间。现在的时间是 00:11。 |
Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.