混沌分形之谢尔宾斯基(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 ...
随机推荐
- 001.NTP简介
一 NTP简介 ntp服务器顾名思义就是时间同步服务器(Network Time Protocol),时间同步对于计划备份.入侵检测记录.分布式任务调度或者事务订单管理来说都是非常有必要的日常任务. ...
- JTree 添加 , 删除, 修改
package com.swing.demo; import java.awt.BorderLayout; import java.awt.Container; import java.awt.eve ...
- IO写 PrintWriter
private static final String FILENAME = "c:\\temp\\out.txt"; PrintWriter pw = null; try { p ...
- HDU.4035.Maze(期望DP)
题目链接 (直接)设\(F(i)\)为在\(i\)点走出迷宫的期望步数.答案就是\(F(1)\). 令\(p_i=1-k_i-e_i\),表示\(i\)点沿着边走的概率:\(d_i=dgr[i]\), ...
- BZOJ.1923.[SDOI2010]外星千足虫(高斯消元 异或方程组 bitset)
题目链接 m个方程,n个未知量,求解异或方程组. 复杂度比较高,需要借助bitset压位. 感觉自己以前写的(异或)高斯消元是假的..而且黄学长的写法都不需要回代. //1100kb 324ms #i ...
- 堆排序的C++代码实现
堆排序C++实现 堆排序的具体思路可以查看<算法导论>这本书,一下只提供笔者的C++实现代码,并且将笔者在编写程序的过程当中所遇到的一些细节问题拿出来作一番解释,希望能够对对堆排序有一个透 ...
- Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) C. Ray Tracing 数学
C. Ray Tracing 题目连接: http://codeforces.com/contest/724/problem/C Description oThere are k sensors lo ...
- mongodb用mongoose查库的对象,不能增加属性
node + koa2 + mongodb 写了一个给前端的接口 如果不是写这个接口,这辈子都发现不了mongodb里这个大坑 mongoose 是个ODM(Object Document Mappe ...
- Java 与 .NET 的平台发展之争
Java 8即将正式发布,从早期版本中,我们已经可以领略到一些令人兴奋的特性.但是开发者Andrew C. Oliver表示,尽管如此,Java语言在某些特性上还是落后于.Net.比如,Java 8中 ...
- 通过WinAPI播放PCM声音
在Windows平台上,播放PCM声音使用的API通常有如下两种. waveOut and waveIn:传统的音频MMEAPI,也是使用的最多的 xAudio2:C++/COM API,主要针对游戏 ...