24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1407  |  回复: 5

Simewe

新虫 (初入文坛)

[求助] Matlab画分形怎么提高速度?

matlab代码
CODE:
function sierpinski(A, B, C, n)
if n == 0
    fill ([A(1), B(1), C(1)], [A(2), B(2), C(2)], [0.0 0.0 0.0]);
    hold on
else
   sierpinski(A, (A + B)/2, (A + C)/2, n-1)
   sierpinski(B, (B + A)/2, (B + C)/2, n-1)
   sierpinski(C, (C + A)/2, (C + B)/2, n-1)
end
%sierpinski([0 0], [1 0], [.5 .8], 8)

mathematica代码
CODE:
sierpinski[{a_, b_, c_}] := With[{ab = (a + b)/2, bc = (b + c)/2, ca = (a + c)/2},
  {{a, ab, ca}, {ab, b, bc}, {ca, bc, c}}];
pts = {{0, 0}, {1, 0}, {.5, .8}};
d = Nest[Join @@ sierpinski /@ # &, {pts}, 8];
Graphics[{EdgeForm@Black, Polygon@d}]

在一个论坛上看到的代码,是画谢尔宾斯基三角形的,同样是迭代了8次,matlab用了近10s,mathematica用1s,
matlab算的慢是不是因为用了递归的原因啊?改成循环或者向量化操作会更快吧
哪位大神帮忙看看
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
Simewe: 金币+10, ★★★很有帮助, nice 2013-09-12 16:44:10
递归可能就这样,你把hold on放在递归函数外面的话,时间会减少一半左右.
原代码需要3.7s在我的机器上运行,hold on提出来后1.8s左右,这个递归的方法挺好的了.三角形都是完整的,如果用chaos game的办法,画出来只是远看的一个近似,放大了都是一些点.速度上也得1.1s左右.
CODE:
function sierpinski(A, B, C, n)
if n == 0
    fill ([A(1), B(1), C(1)], [A(2), B(2), C(2)], [0.0 0.0 0.0]);
else
   sierpinski(A, (A + B)/2, (A + C)/2, n-1)
   sierpinski(B, (B + A)/2, (B + C)/2, n-1)
   sierpinski(C, (C + A)/2, (C + B)/2, n-1)
end

%figure;hold on;
%sierpinski([0 0], [1 0], [.5 .8], 8)

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2013-09-11 17:18:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Simewe

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by libralibra at 2013-09-11 17:18:13
递归可能就这样,你把hold on放在递归函数外面的话,时间会减少一半左右.
原代码需要3.7s在我的机器上运行,hold on提出来后1.8s左右,这个递归的方法挺好的了.三角形都是完整的,如果用chaos game的办法,画出来只是远看 ...

这样是快了点,但我想知道怎么把递归改成循环呢?matlab里的递归据说比python更慢,
正好我也有python版的代码(使用循环)
CODE:
from matplotlib import collections as coll, pyplot as plt
import numpy as np
from time import time
st=time()

def sierpinski(a,b,c):
    return [[a, (a + c)/2, (a + b)/2], [(a + b)/2, b, (b + c)/2], [(a + c)/2, (b + c)/2, c]]

pts=np.array([[[0.,0.], [1.,0.], [.5,.8]]])
for n in range(8):
    pts=[y for x in [sierpinski(*i) for i in pts] for y in x]

print np.shape(pts)
plt.gca().add_collection(coll.PolyCollection( pts ))
plt.axis('scaled')
print time()-st
plt.show()

3楼2013-09-11 18:47:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

引用回帖:
3楼: Originally posted by Simewe at 2013-09-11 18:47:10
这样是快了点,但我想知道怎么把递归改成循环呢?matlab里的递归据说比python更慢,
正好我也有python版的代码(使用循环)

from matplotlib import collections as coll, pyplot as plt
import numpy as np
...

matlab也用循环的话,快的可怕,0.12s左右
CODE:
tic;
% 原始三角形顶点,保存在一个n*3*2的数组,第三维共2层,第一层是x,第二层是y
pts(:,:,1) = [0,1,0.5];
pts(:,:,2) = [0,0,0.8];
% 层数
layer = 8;
% 当前层的三角形顶点
cur_pts = pts;
while layer>0
    next_pts = []; % 利用当前层顶点计算出来下一层的三角形顶点
    for num=1:size(cur_pts,1)
        % 利用三顶点计算分形三角形顶点坐标
        a = cur_pts(num,1,:);
        b = cur_pts(num,2,:);
        c = cur_pts(num,3,:);
        next_pts(end+1:end+3,:,:) = [a,(a+c)/2,(a+b)/2;
            (a+b)/2,b,(b+c)/2;
            (a+c)/2,(b+c)/2,c];
    end
    % 迭代当前层顶点
    cur_pts = next_pts;
    % 将顶点加入结果数组
    pts(end+1:end+size(cur_pts,1),:,:) = cur_pts;
    % 层数递减
    layer = layer-1;
end
% 作图
patch(pts(:,:,1)',pts(:,:,2)','w');
toc;

效果图
Matlab画分形怎么提高速度?
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
4楼2013-09-11 23:28:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Simewe

新虫 (初入文坛)

引用回帖:
4楼: Originally posted by libralibra at 2013-09-11 23:28:12
matlab也用循环的话,快的可怕,0.12s左右
tic;
% 原始三角形顶点,保存在一个n*3*2的数组,第三维共2层,第一层是x,第二层是y
pts(:,:,1) = ;
pts(:,:,2) = ;
% 层数
layer = 8;
% 当前层的三角形顶点
cur_pts ...

其实递归也能再加快的,我又找到了一种方法
CODE:
function r = sierpinski(a, b, c, n)
    if n == 0
        r = [a; b; c];
    else
        r=[sierpinski(a, (a+b)/2, (a+c)/2, n-1);
           sierpinski((b+a)/2, b, (b+c)/2, n-1);
           sierpinski((c+a)/2, (c+b)/2, c, n-1)];
    end
end

%{
tic;
n=8;
V = sierpinski([0,0],[1,0],[0.5,0.8],n);
F = reshape(1:length(V),3,[])';
patch('Vertices',V,'Faces', F);
toc;
%}

5楼2013-09-12 16:50:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

BJRR

新虫 (正式写手)

很好哦。。。。。
6楼2015-09-08 10:10:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 Simewe 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +4 电气小神童 2026-04-04 6/300 2026-04-07 00:14 by guanxin1001
[考研] 0854求调剂 +7 亨氏番茄沙司 2026-04-06 8/400 2026-04-06 17:27 by 土木硕士招生
[考研] 求调剂 +11 xzghyuj 2026-04-04 11/550 2026-04-06 11:49 by lijunpoly
[考研] 一志愿南京航空航天大学 材料与化工329分求调剂 +8 Mr. Z 2026-04-05 8/400 2026-04-06 09:24 by dongzh2009
[考研] 生物与医药调剂 +4 十七sa 2026-04-05 4/200 2026-04-05 20:05 by lys0704
[考研] 329求调剂 +17 miaodesi 2026-04-02 20/1000 2026-04-05 18:33 by 蓝云思雨
[考研] 275求调剂 +16 waltzh 2026-04-01 16/800 2026-04-05 17:14 by Hdyxbekcb
[考研] 一志愿西北农林畜牧专硕336分求调剂 +3 5ourr 2026-04-03 3/150 2026-04-05 10:40 by JOKER0401
[考研] 288求调剂,一志愿华南理工大学071005 +6 ioodiiij 2026-04-04 6/300 2026-04-05 10:09 by guoweigw
[考研] 一志愿华北电力大学(北京),材料科学与工程学硕265,求调剂 +11 yelck 2026-04-03 12/600 2026-04-04 19:52 by dongzh2009
[考研] 材料调剂 +11 吴棂颖! 2026-04-03 11/550 2026-04-04 09:56 by 小小树2024
[考研] 求调剂,一志愿南京航空航天大学 ,080500材料科学与工程学硕 +10 @taotao 2026-04-03 10/500 2026-04-04 09:01 by T可可西里T
[考研] 283分材料与化工求调剂 +29 罗KAKA 2026-04-02 29/1450 2026-04-03 23:56 by userper
[考研] 五邑大学土木工程招调剂生2026 +3 wyutj 2026-03-31 4/200 2026-04-03 18:21 by zengxj_7201
[考研] 081200-11408-276学硕求调剂 +5 崔wj 2026-04-03 5/250 2026-04-03 15:06 by arrow8852
[考研] 085600专硕材料与化工348分求调剂 +10 上学啦! 2026-04-01 11/550 2026-04-03 14:13 by 百灵童888
[考研] 282求调剂 +5 呼吸都是减肥 2026-03-31 5/250 2026-04-03 12:03 by 1753564080
[考研] 279求调剂 +6 qazplm0852 2026-04-02 6/300 2026-04-03 10:03 by 蓝云思雨
[考研] 302求调剂一志愿北航070300,本科郑大化学 +8 圣日耳曼条 2026-04-01 11/550 2026-04-02 07:40 by chemdavid
[考研] 一志愿西电085401数一英一299求调剂 六级521 +4 爱吃大鸭梨 2026-03-31 4/200 2026-03-31 11:51 by 搏击518
信息提示
请填处理意见