3

MATLAB 的优化器是否对 MATLAB 代码执行公共子表达式消除?例如:

if max(val) > minVal && max(val) < maxVal
    maxVal = max(val)
end

那里多久max(val)评估一次?将中间值存储在临时变量中是否有意义(假设重复计算很昂贵)还是 MATLAB 会自动处理?

4

1 回答 1

3

很确定答案是否定子表达式消除和存储中间值是肯定的。例子:

>> x = rand(10000, 1);
>> tic;
for i = 1:100000
  y = max(x) + max(x);
end
toc;
Elapsed time is 4.297135 seconds.
>> tic;
for i = 1:100000
  m = max(x);
  y = m + m;
end
toc;
Elapsed time is 1.074672 seconds.

甚至像 + 这样的内置操作似乎也没有得到优化;类似的测试表明

z = (x + x);
y = z + z + z;

比:

y = (x + x) + (x + x) + (x + x);
于 2012-09-06T10:56:38.760 回答