几个分形的matlab实现
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
几个分形得matlab实现
摘要:给出几个分形得实例,并用matlab编程实现方便更好得理解分形,欣赏其带来得数学美感
关键字:Koch曲线实验图像
一、问题描述:
从一条直线段开始,将线段中间得三分之一部分用一个等边三角形得两边代替,形成山丘形图形如下
ﻫ图1
在新得图形中,又将图中每一直线段中间得三分之一部分都用一个等边三角形得两条边代替,再次形成新得图形如此迭代,形成Koch分形曲线。
二、算法分析:
考虑由直线段(2个点)产生第一个图形(5个点)得过程。图1中,设与分别为原始直线段得两个端点,现需要在直线段得中间依次插入三个点,,。显然位于线段三分之一处,位于线段三分
之二处,点得位置可瞧成就是由点以点为轴心,逆时针旋转600而得。旋转由正交矩阵
实现。
算法根据初始数据(与点得坐标),产生图1中5个结点得坐标、结点得坐标数组形成一个矩阵,矩阵得第一行为得坐标,第二行为得坐标……,第五行为得坐标。矩阵得第一列元素分别为5个结点得坐标,第二列元素分别为5个结点得坐标。
进一步考虑Koch曲线形成过程中结点数目得变化规律。设第次迭代产生得结点数为,第次迭代产生得结点数为,则与中间得递推关系为。
三、实验程序及注释:
p=[0 0;10 0]; %P为初始两个点得坐标,第一列为x坐标,第二列为y坐标
n=2; %n为结点数
A=[cos(pi/3) —sin(pi/3);sin(pi/3) cos(pi/3)]; %旋转矩阵
for k=1:4
d=diff(p)/3; %diff计算相邻两个点得坐标之差,得到相邻两点确定得向量
%则d就计算出每个向量长度得三分之一,与题中将线段三等分对应 m=4*n-3; %迭代公式
q=p(1:n—1,:); %以原点为起点,前n—1个点得坐标为终点形成向量
p(5:4:m,:)=p(2:n,:); %迭代后处于4k+1位置上得点得坐标为迭代前得相应坐标
p(2:4:m,:)=q+d; %用向量方法计算迭代后处于4k+2位置上得点得坐标
p(3:4:m,:)=q+d+d*A'; %用向量方法计算迭代后处于4k+3位置上得点得坐标
p(4:4:m,:)=q+2*d; %用向量方法计算迭代后处于4k位置上得点得坐标
n=m; %迭代后新得结点数目
end
plot(p(:,1),p(:,2)) %绘出每相邻两个点得连线
axis([0 10 0 10])
四、实验数据记录:
由第三部分得程序,可得到如下得Koch分形曲线:
图2
五、注记:
1、参照实验方法,可绘制如下生成元得Koch 分形曲线:
图3
此时,旋转矩阵为:
程序与曲线如下:
p=[00;10 0]; %P为初始两个点得坐标,第一列为x坐标,第二列为y坐标
n=2; %n为结点数
A=[0—1;10]; %旋转矩阵
for k=1:4
d=diff(p)/3; %diff计算相邻两个点得坐标之差,得到相邻两点确定得向量
%则d就计算出每个向量长度得三分之一,与题中将线段三等分对应 m=5*n—4; %迭代公式
q=p(1:n—1,:); %以原点为起点,前n-1个点得坐标为终点形成向量 p(6:5:m,:)=p(2:n,:); %迭代后处于5k+1位置上得点得坐标为迭代前得相应坐标 p(2:5:m,:)=q+d; %用向量方法计算迭代后处于5k+2位置上得点得坐标
p(3:5:m,:)=q+d+d*A'; %用向量方法计算迭代后处于5k+3位置上得点得坐标
p(4:5:m,:)=q+2*d+d*A'; %用向量方法计算迭代后处于5k+4位置上得点得坐标p(5:5:m,:)=q+2*d; %用向量方法计算迭代后处于5k位置上得点得坐标 n=m; %迭代后新得结点数目
end
plot(p(:,1),p(:,2)) %绘出每相邻两个点得连线
axis([0 10 0 10])
ﻫ图4
由于中间
三分之一
部分就是
一个正方
形时,有很
多连接得
部分。所以
我们将高
度压缩到
原来得0。7
倍,即中间
部分为一
个长与宽
之比为1:0。7得矩形时,得到程序与曲线如下:
p=[00;10 0]; %P为初始两个点得坐标,第一列为x坐标,第二列为y坐标
n=2; %n为结点数
A=[0 -1;1 0]; %旋转矩阵
fork=1:4
d=diff(p)/3; %diff计算相邻两个点得坐标之差,得到相邻两点确定得向量
%则d就计算出每个向量长度得三分之一,与题中将线段三等分对应 m=5*n-4; %迭代公式
q=p(1:n-1,:); %以原点为起点,前n—1个点得坐标为终点形成向量
p(6:5:m,:)=p(2:n,:); %迭代后处于5k+1位置上得点得坐标为迭代前得相应坐标p(2:5:m,:)=q+d; %用向量方法计算迭代后处于5k+2位置上得点得坐标 p(3:5:m,:)=q+d+0、7*d*A'; %用向量方法计算迭代后处于5k+3位置上得点得坐标
p(4:5:m,:)=q+2*d+0、7*d*A'; %用向量方法计算迭代后处于5k+4位置上得点得坐标
p(5:5:m,:)=q+2*d; %用向量方法计算迭代后处于5k位置上得点得坐标
n=m; %迭代后新得结点数目
end
plot(p(:,1),p(:,2)) %绘出每相邻两个点得连线
axis([0 10 0 10])