sierpinski.m
来自「matlab图像处理源代码 大家多多分享」· M 代码 · 共 39 行
M
39 行
function sierpinski(x,y,z,n)
%x为初始三角形的第一个顶点的坐标
%y为初始三角形的第二个顶点的坐标
%z为初始三角形的第三个顶点的坐标
%n为迭代次数
x1=x(1);
x2=x(2);
y1=y(1);
y2=y(2);
z1=z(1);
z2=z(2);
for j=1:n
a1=[];
a2=[];
b1=[];
b2=[];
c1=[];
c2=[];
for i=1:length(x1)
a1=[a1,x1(i),(x1(i)+y1(i))/2,(x1(i)+z1(i))/2];
a2=[a2,x2(i),(x2(i)+y2(i))/2,(x2(i)+z2(i))/2];
b1=[b1,(x1(i)+y1(i))/2,y1(i),(y1(i)+z1(i))/2];
b2=[b2,(x2(i)+y2(i))/2,y2(i),(y2(i)+z2(i))/2];
c1=[c1,(x1(i)+z1(i))/2,(y1(i)+z1(i))/2,z1(i)];
c2=[c2,(x2(i)+z2(i))/2,(y2(i)+z2(i))/2,z2(i)];
end
x1=a1;
x2=a2;
y1=b1;
y2=b2;
z1=c1;
z2=c2;
end
for i=1:length(x1)
fill([x1(i),y1(i),z1(i),x1(i)],[x2(i),y2(i),z2(i),x2(i)],'b');
hold on
end
hold off
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?