关于MATLABFOR循环的思考

MATLB矩阵运算

MATLAB对于矩阵的运算其实是很友好的,大多数对于数据的二维for循环嵌套其实都可以改写为矩阵运算;
例如,我们有以下这个例子:

sj(1:2*N)=0;
for i=1:2*N
    for j=1:500
        sj(i)=sj(i)+(j-1)*S_A(j)*P_A(j)*sin(S_f(j)-P_f(j)+(j-1)*(i-N)/100000000/N*2*pi);
    end
end

这段代码等价于:

I = (1:2*N)';
J = 1:500;
ONE = ones(2*N,1);

Matra = ONE * ( (J-1).*S_A(J).* P_A(J) ) .* sin( ONE * (S_f(J) - P_f(J)) + (I-N) * (J-1)/100000000/N*2*pi );
sj = Matra * ones(500,1);

代码量似乎是没有多大的差别的,但是在运算速度上面,后面采用的矩阵的乘法和矩阵函数的功能,在MATLAB的环境中更为友好,相对了连个for循环一个一个遍历的方法,速度上会有质的提高。
在MATLAB中,要充分利用矩阵索引,矩阵乘法、点乘、矩阵函数、特殊矩阵等线性代数的方式来组织运算,对于优化运算速度会有很大的提升。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值