当前位置 : 主页 > 网络安全 > 测试自动化 >

性能 – Vectorize Double Loop – MATLAB

来源:互联网 收集:自由互联 发布时间:2021-06-22
我有一个双循环,这是非常低效的. c is a [400,2000] matrixr is a [2000,1] matrixP is a [2000,1] matrixS is a [1, 400] matrixfor i=1:400 for k=1:2000 c(i,k) = r(k,1) * max([0, P(k,1) - S(1,i)]); endend 我试图制作一个parfor并
我有一个双循环,这是非常低效的.

c is a [400,2000] matrix
r is a [2000,1] matrix
P is a [2000,1] matrix
S is a [1, 400] matrix


for i=1:400
    for k=1:2000
        c(i,k) = r(k,1) * max([0, P(k,1) - S(1,i)]);
    end
end

我试图制作一个parfor并且它有效.但我一直在寻找更优雅的解决方案.我一直在努力尝试但没有运气……

由于您只进行元素操作,如 – 和.*,这需要使用 bsxfun的解决方案.

使用

bsxfun(@minus,P,S)

做元素减法P(k,1) – S(1,i).输出将是[2000,400]矩阵.您可以对此矩阵应用max(0,…)运算,最后再次使用bsxfun将每一行乘以相应的r:

bsxfun(@times,max(bsxfun(@minus,P,S),0),r)

由于你的c应该是[400,2000]的大小,添加一个最终的转置操作,你就完成了.

c = bsxfun(@times,max(bsxfun(@minus,P,S),0),r).';

一个小的时间比较:for循环需要

Elapsed time is 0.688408 seconds.

而bsxfun解决方案只需要

Elapsed time is 0.007884 seconds.

对于完全相同的结果,这是一个很好的加速87.

网友评论