Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
|
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
我正在做以下
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的大小。 您需要稍作更改,但是这样做会更快。如果您对当前的速度不满意,请不要进行任何更改! 更多&回答... |
![]() |
![]() |