混沌分形之谢尔宾斯基(Sierpinski)
本文以使用混沌方法生成若干种谢尔宾斯基相关的分形图形。
(1)谢尔宾斯基三角形
给三角形的3个顶点,和一个当前点,然后以以下的方式进行迭代处理:
a.随机选择三角形的某一个顶点,计算出它与当前点的中点位置;
b.将计算出的中点做为当前点,再重新执行操作a
相关代码如下:
class SierpinskiTriangle : public FractalEquation
{
public:
SierpinskiTriangle()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f; m_triangleX[] = 0.0f;
m_triangleY[] = FRACTAL_RADIUS; m_triangleX[] = FRACTAL_RADIUS*sinf(PI/);
m_triangleY[] = -FRACTAL_RADIUS*sinf(PI/); m_triangleX[] = -m_triangleX[];
m_triangleY[] = m_triangleY[];
} void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
int r = rand()%;
outX = (x + m_triangleX[r])*0.5f;
outY = (y + m_triangleY[r])*0.5f;
outZ = z;
} private:
float m_triangleX[];
float m_triangleY[];
};
关于基类FractalEquation的定义见:混沌与分形
最终生成的图形为:

通过这一算法可以生成如下图像:

(2)谢尔宾斯基矩形
既然能生成三角形的图形,那么对于矩形会如何呢?尝试下吧:
class SierpinskiRectangle : public FractalEquation
{
public:
SierpinskiRectangle()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f; m_ParamA = 1.0f;
m_ParamB = 1.0f; m_rectX[] = FRACTAL_RADIUS;
m_rectY[] = FRACTAL_RADIUS; m_rectX[] = FRACTAL_RADIUS;
m_rectY[] = -FRACTAL_RADIUS; m_rectX[] = -FRACTAL_RADIUS;
m_rectY[] = -FRACTAL_RADIUS; m_rectX[] = -FRACTAL_RADIUS;
m_rectY[] = FRACTAL_RADIUS;
} void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
int r = rand()%;
outX = (x + m_rectX[r])*0.5f;
outY = (y + m_rectY[r])*0.5f;
outZ = z;
} bool IsValidParamA() const {return true;}
bool IsValidParamB() const {return true;} void SetParamA(float v)
{
m_ParamA = v; m_rectX[] = FRACTAL_RADIUS*m_ParamA;
m_rectX[] = FRACTAL_RADIUS*m_ParamA;
m_rectX[] = -FRACTAL_RADIUS*m_ParamA;
m_rectX[] = -FRACTAL_RADIUS*m_ParamA;
} void SetParamB(float v)
{
m_ParamB = v; m_rectY[] = FRACTAL_RADIUS*m_ParamB;
m_rectY[] = -FRACTAL_RADIUS*m_ParamB;
m_rectY[] = -FRACTAL_RADIUS*m_ParamB;
m_rectY[] = FRACTAL_RADIUS*m_ParamB;
} private:
float m_rectX[];
float m_rectY[];
};
图形如下:

噢,SHIT,毫无规律可言。
那就变动一下吧:
class FractalSquare : public FractalEquation
{
public:
FractalSquare()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f; m_rectX[] = FRACTAL_RADIUS;
m_rectY[] = FRACTAL_RADIUS; m_rectX[] = FRACTAL_RADIUS;
m_rectY[] = -FRACTAL_RADIUS; m_rectX[] = -FRACTAL_RADIUS;
m_rectY[] = -FRACTAL_RADIUS; m_rectX[] = -FRACTAL_RADIUS;
m_rectY[] = FRACTAL_RADIUS;
} void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
int r = rand()%;
if (r < )
{
outX = (x + m_rectX[r])*0.5f;
outY = (y + m_rectY[r])*0.5f;
}
else
{
outX = x*0.5f;
outY = y*0.5f;
}
outZ = z;
} private:
float m_rectX[];
float m_rectY[];
};

看上去还有点样。
(3)谢尔宾斯基五边形
四边形是不行的,那再试下五边:
// 五边形
class SierpinskiPentagon : public FractalEquation
{
public:
SierpinskiPentagon()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f; for (int i = ; i < ; i++)
{
m_pentagonX[i] = sinf(i*PI*/);
m_pentagonY[i] = cosf(i*PI*/);
}
} void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
int r = rand()%;
outX = (x + m_pentagonX[r])*0.5f;
outY = (y + m_pentagonY[r])*0.5f;
outZ = z;
} private:
float m_pentagonX[];
float m_pentagonY[];
};

有点样子,那就以此算法为基础,生成幅图像看看:

有人称谢尔宾斯基三角形为谢尔宾斯基坟垛,当我看到这幅图时,有一种恐怖的感觉。邪恶的五角形,总感觉里面有数不清的骷髅。
看来二维空间中谢尔宾斯基的单数可以生成分形图形,而双数则为无序的混沌。
(4)谢尔宾斯基四面体
再由二维扩展到三维看看:
class SierpinskiTetrahedron : public FractalEquation
{
public:
SierpinskiTetrahedron()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f; m_vTetrahedron[] = YsVector(0.0f, 0.0f, 0.0f);
m_vTetrahedron[] = YsVector(0.0f, 1.0f, 0.0f);
m_vTetrahedron[] = YsVector(YD_REAL_SQRT_3/, 0.5f, 0.0f);
m_vTetrahedron[] = YsVector(YD_REAL_SQRT_3/, 0.5f, YD_REAL_SQRT_3*YD_REAL_SQRT_2/); YsVector vCenter = m_vTetrahedron[] + m_vTetrahedron[] + m_vTetrahedron[] + m_vTetrahedron[];
vCenter *= 0.25f; m_vTetrahedron[] -= vCenter;
m_vTetrahedron[] -= vCenter;
m_vTetrahedron[] -= vCenter;
m_vTetrahedron[] -= vCenter; m_vTetrahedron[] *= FRACTAL_RADIUS;
m_vTetrahedron[] *= FRACTAL_RADIUS;
m_vTetrahedron[] *= FRACTAL_RADIUS;
m_vTetrahedron[] *= FRACTAL_RADIUS;
} void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
int r = rand()%;
outX = (x + m_vTetrahedron[r].x)*0.5f;
outY = (y + m_vTetrahedron[r].y)*0.5f;
outZ = (z + m_vTetrahedron[r].z)*0.5f;
} bool Is3D() const {return true;} private:
YsVector m_vTetrahedron[];
};

(5)其他
谢尔宾斯基三角形是一种很神的东西,我写过一些生成图像的算法,常常不知不觉中就出现了谢尔宾斯基三角形。如细胞生长机

再如:

之前我写过几篇与谢尔宾斯基分形相关的文章
混沌分形之谢尔宾斯基(Sierpinski)的更多相关文章
- 分形之谢尔宾斯基(Sierpinski)三角形
谢尔宾斯基三角形(英语:Sierpinski triangle)是一种分形,由波兰数学家谢尔宾斯基在1915年提出,它是一种典型的自相似集.也有的资料将其称之为谢尔宾斯基坟垛. 其生成过程为: 取一个 ...
- 分形之谢尔宾斯基(Sierpinski)地毯
前面讲了谢尔宾斯基三角形,和这一节的将把三角形变为正方形,即谢尔宾斯基地毯,它是由瓦茨瓦夫·谢尔宾斯基于1916年提出的一种分形,是自相似集的一种. 谢尔宾斯基地毯的构造与谢尔宾斯基三角形相似,区别仅 ...
- 分形之谢尔宾斯基(Sierpinski)四面体
前面讲了谢尔宾斯基三角形,这一节的将对二维三角形扩展到三维,变成四面体.即将一个正四面体不停地拆分,每个正四面体可以拆分成四个小号的正四面体.由二维转变到三维实现起来麻烦了许多.三维的谢尔宾斯基四面体 ...
- 【数据结构与算法Python版学习笔记】递归(Recursion)——定义及应用:分形树、谢尔宾斯基三角、汉诺塔、迷宫
定义 递归是一种解决问题的方法,它把一个问题分解为越来越小的子问题,直到问题的规模小到可以被很简单直接解决. 通常为了达到分解问题的效果,递归过程中要引入一个调用自身的函数. 举例 数列求和 def ...
- python---使用递归实现谢尔宾斯基三角形及汉诺塔
渐入佳境. # coding: utf-8 import turtle ''' # =================turtle练手== def draw_spiral(my_turtle, lin ...
- 小练手:用HTML5 Canvas绘制谢尔宾斯基三角形
文章首发于我的知乎专栏,原地址:https://zhuanlan.zhihu.com/p/26606208 以前看到过一个问题:谢尔宾斯基三角形能用编程写出来么?该怎么写? - 知乎,在回答里,各方大 ...
- python 使用turtule绘制递归图形(螺旋、二叉树、谢尔宾斯基三角形)
插图工具使用Python内置的turtle模块,为什么叫这个turtle乌龟这个名字呢,可以这样理解,创建一个乌龟,乌龟能前进.后退.左转.右转,乌龟的尾巴朝下,它移动时就会画一条线.并且为了增加乌龟 ...
- Python使用递归绘制谢尔宾斯基三角形
谢尔宾斯基三角形使用了三路递归算法,从一个大三角形开始,通过连接每一个边的中点,将大三角型分为四个三角形,然后忽略中间的三角形,依次对其余三个三角形执行上述操作. 运行效果: 源代码: 1 impor ...
- 混沌分形之迭代函数系统(IFS)
IFS是分形的重要分支.它是分形图像处理中最富生命力而且最具有广阔应用前景的领域之一.这一工作最早可以追溯到Hutchinson于1981年对自相似集的研究.美国科学家M.F.Barnsley于198 ...
随机推荐
- BZOJ.2668.[CQOI2012]交换棋子(费用流zkw)
题目链接 首先黑白棋子的交换等价于黑棋子在白格子图上移动,都到达指定位置. 在这假设我们知道这题用网络流做. 那么黑棋到指定位置就是一条路径,考虑怎么用流模拟出这条路径. 我们发现除了路径的起点和终点 ...
- BZOJ4275 : [ONTAK2015]Badania naukowe
设f[i][j]为a[1..i]与b[1..j]的LCS,g[i][j]为a[i..n]与b[j..m]的LCS. 若C为0,则ans=f[n][m]. 否则求出d[i]=a中从i开始往右匹配上c串的 ...
- Codeforces Round #371 (Div. 2) D. Searching Rectangles 交互题 二分
D. Searching Rectangles 题目连接: http://codeforces.com/contest/714/problem/D Description Filya just lea ...
- hdu 5726 GCD 暴力倍增rmq
GCD/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5726 Description Give you a sequence ...
- java并发基础(三)--- 任务执行
第6章开始是第二部分,讲解结构化并发应用程序,大多数并发应用程序都是围绕“任务执行”构造的,任务通常是一些抽象的且离散的工作单元. 一.线程池 大多数服务器应用程序都提供了一种自然的任务边界:以独立的 ...
- What is CMSIS-DAP
The mbed HDK and mbed-enabled hardware support the CMSIS-DAP debug interface, which consists of an a ...
- Revit API通过相交过滤器找到与风管相交的对象。
相交过滤器的应用,比几何相交法简便.Excluding剔除 //找到与风管相交的对象,通过相交过滤器. [TransactionAttribute(Autodesk.Revit.Attributes. ...
- .NET开源作业调度框架(Quartz.NET和FluentScheduler)实战项目演练
一.课程介绍 明人不说暗话,跟着阿笨一起玩NET .本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的一部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享 ...
- 在ASP.NET MVC中使用Castle Windsor
平常用Inject比较多,今天接触到了Castle Windsor.本篇就来体验其在ASP.NET MVC中的应用过程. Visual Studio 2012创建一个ASP.NET MVC 4网站. ...
- Android:Attribute is missing the Android namespace prefix
今天编写XML文件时,出现了Attribute is missing the Android namespace prefix的错误,开始一直找没找出原因,后来仔细一看原来只是一个很简单的单词书写错误 ...