24小时热门版块排行榜    

查看: 2069  |  回复: 15

myw052

金虫 (正式写手)

博士

[求助] matlab for循环速度 提高方法

下面的程序是我用matlab写的一个程序,程序中需要用到for循环,由于是高位矩阵,在运行的时候循环速度效率很低,造成计算成本很大。在许多论坛上寻找好的方法来解决matlab运行中循环的速度提高方法,始终没有找到。有人说用矢量化解决问题,但是描述的不具体,操作起来有困难。有人说用“少拿多取”的思想,但是在简单情况下,可以理解,像如下的情况,似乎难以实行。

故在本版发帖,希望斑竹或者各位程序达人能出来指点一二。本人不胜感激。
(注:此贴绝不是无病呻吟)。

function for_cycle()
tic
clc
clear
close all
beta=rand(10^5,10,10);
gama=rand(10^5,10,10);

[Row,Column,Volume]=size(beta);
gama_u=rand(1,1);
m=2;

for k=1:Volume                     
    k
    for i=1:Row                    
        for j=1:Column               
            D(i,j,k)=beta(i,j,k)/(beta(i,j,k)+(1-beta(i,j,k))*(gama(i,j,k)-(gama(i,j,k)/gama_u)^m)/(gama(i,j,k)-1));
        end
    end
end

D
toc
end
回复此楼
天天快乐
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sudo

木虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 欢迎常来 2012-04-24 13:54:50
myw052: 金币+7, ★★★★★最佳答案, 您的程序写的很好,矢量化确实很厉害。 2012-04-24 18:52:29
把规模改小了,方便对比测试
CODE:
tic
clc
clear
close all
beta=rand(10,10,10);
gama=rand(10,10,10);

[Row,Column,Volume]=size(beta);
gama_u=rand(1,1);
m=2;

D=zeros(size(beta));

for k=1:Volume                    
    for i=1:Row                    
        for j=1:Column               
            D(i,j,k)=beta(i,j,k)/(beta(i,j,k)+(1-beta(i,j,k))*(gama(i,j,k)-(gama(i,j,k)/gama_u)^m)/(gama(i,j,k)-1));
        end
    end
end

D
toc

tic
D_vectorized = beta ./ ( beta + (ones(size(beta)) - beta) .* (gama-(gama/gama_u).^m) ./ (gama - ones(size(gama))) )
toc

2楼2012-04-24 10:42:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sudo

木虫 (正式写手)

这就是传说中的矢量化
3楼2012-04-24 10:43:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖


感谢参与,应助指数 +1
myw052: 金币+1, 嗯,这个道理我还是懂的。只是对于高维数组有时候想要实现比较麻烦。 2012-04-24 18:56:50
matlab上说 矩阵运算比for循环高效很多
4楼2012-04-24 12:24:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhfzh

木虫 (正式写手)

你拭下用矢量化计算
就是把for,end去了,常数乘个同维度的单位阵,所有的乘除号前加点
还有你算beta,gamma的时候不要重复调用,用个临时变量存起来
还慢的话你用C语言写吧
5楼2012-04-24 12:31:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhfzh

木虫 (正式写手)

【答案】应助回帖


感谢参与,应助指数 +1
myw052: 金币+1 2012-04-24 18:56:17
你拭下用矢量化计算
就是把for,end去了,常数乘个同维度的单位阵,所有的乘除号前加点
还有你算beta,gamma的时候不要重复调用,用个临时变量存起来
还慢的话你用C语言写吧
6楼2012-04-24 12:32:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lurencyj

木虫 (著名写手)

【答案】应助回帖


感谢参与,应助指数 +1
myw052: 金币+1, 感谢您的帮助。 2012-04-24 18:57:04
楼主可以尝试使用matlab里面的冒号。可以极大的提高程序的效率,避免低效的for和while循环。
很女子很弓虽大
7楼2012-04-24 16:41:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

myw052

金虫 (正式写手)

博士

引用回帖:
7楼: Originally posted by lurencyj at 2012-04-24 16:41:34:
楼主可以尝试使用matlab里面的冒号。可以极大的提高程序的效率,避免低效的for和while循环。

我的理解,冒号操作,只是产生数组。譬如N=-1:0.1:1
能避免for循环么?
lurencyj能否给一个小例子验证下。。。
天天快乐
8楼2012-04-24 18:55:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

myw052

金虫 (正式写手)

博士

引用回帖:
6楼: Originally posted by zhfzh at 2012-04-24 12:32:12:
你拭下用矢量化计算
就是把for,end去了,常数乘个同维度的单位阵,所有的乘除号前加点
还有你算beta,gamma的时候不要重复调用,用个临时变量存起来
还慢的话你用C语言写吧

嗯,你的方法跟前面sudo说的一样。C很久不用了,生疏了。
天天快乐
9楼2012-04-24 18:56:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lurencyj

木虫 (著名写手)

【答案】应助回帖

CODE:
A = rand(4,4);

B = ones(4,1);

B(:) = sin(A(:,1))

B(:) = sin(A(:,2))

[ 发自手机版 http://muchong.com/3g ]
很女子很弓虽大
10楼2012-04-24 19:15:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 myw052 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 326求调剂 +3 上岸的小葡 2026-03-15 4/200 2026-03-15 18:50 by 无际的草原
[考研] 0856专硕279求调剂 +5 加油加油!? 2026-03-15 5/250 2026-03-15 11:58 by 2020015
[考研] 304求调剂 +5 小熊joy 2026-03-14 5/250 2026-03-14 21:07 by peike
[基金申请] 面上和青基一样限30页不合理 +5 wowsunflower 2026-03-10 7/350 2026-03-14 17:21 by kingkocxr
[教师之家] 焦虑 +5 水冰月月野兔 2026-03-13 7/350 2026-03-14 15:14 by 农药害害
[考研] 331求调剂(0703有机化学 +5 ZY-05 2026-03-13 6/300 2026-03-14 10:51 by Jy?
[考研] 0703化学求调剂 +5 很老实人 2026-03-09 5/250 2026-03-14 02:57 by JourneyLucky
[考研] 293求调剂 +5 上班不着吉 2026-03-09 5/250 2026-03-14 02:37 by JourneyLucky
[考研] 333求调剂 +3 球球古力 2026-03-09 3/150 2026-03-14 01:57 by JourneyLucky
[考研] 求调剂! +4 朔朔话 2026-03-09 4/200 2026-03-14 01:38 by JourneyLucky
[考研] 材料工程专硕,一志愿中国矿业大学,总分314,求调剂 +5 无懈可击的巨人 2026-03-10 5/250 2026-03-14 00:37 by JourneyLucky
[考研] 复试调剂 +9 Copy267 2026-03-10 9/450 2026-03-13 23:45 by userper
[考研] 304求调剂 +6 Mochaaaa 2026-03-12 7/350 2026-03-13 22:18 by 星空星月
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +6 步川酷紫123 2026-03-13 6/300 2026-03-13 21:59 by 星空星月
[考研] 一志愿西南交大,材料专硕317求调剂 +5 lx8568 2026-03-11 5/250 2026-03-13 21:43 by peike
[考研] 0703化学一志愿211 总分320求调剂 +5 玛卡巴卡啊哈 2026-03-11 5/250 2026-03-13 21:40 by JourneyLucky
[考研] (081700)化学工程与技术-298分求调剂 +12 11啦啦啦 2026-03-11 35/1750 2026-03-13 21:25 by JourneyLucky
[硕博家园] 深圳大学硕士招生(2026秋,传感器方向,仅录取第一志愿) +4 xujiaoszu 2026-03-11 7/350 2026-03-13 17:28 by xujiaoszu
[考研] 293求调剂,一志愿陕师大生物学 +3 ??????.?.??? 2026-03-09 3/150 2026-03-11 10:02 by 学员8dgXkO
[考研] 化工0817调剂 +8 灿若星晨 2026-03-10 8/400 2026-03-10 22:44 by 星空星月
信息提示
请填处理意见