混沌分形之谢尔宾斯基(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 ...
随机推荐
- 012.Zabbix的IT服务
一 IT服务简介 IT服务能体现宏观度量和管理基础设施的总体情况的可用性,从而体现总体的趋势,发现并解决IT基础设施暴露的问题. 二 IT服务的添加 2.1 IT services--services ...
- Codeforces Round #374 (Div. 2) A. One-dimensional Japanese Crosswor 水题
A. One-dimensional Japanese Crossword 题目连接: http://codeforces.com/contest/721/problem/A Description ...
- UVALive 6911 Double Swords 树状数组
Double Swords 题目连接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8 ...
- 初始化collectionViewCell
#import <UIKit/UIKit.h> @interface TonyCollectionViewCell : UICollectionViewCell @property UII ...
- Windows 10原版ISO下载地址(持续更新)
Windows 10本质上,它们与 Win7.XP 时代的 SP1.SP2.SP3 这样的大型更新版是一样的,只不过微软很蛋疼地为它们起上一个难记地要死的名字,仅此而已.如果你把“一周年更新”看作 S ...
- 使用CefSharp在.Net程序中嵌入Chrome浏览器(五)——Javascript交互
要在CEF中和网页的JS进行交互,首先我们要通过设置启用Javascrit集成功能. CefSharpSettings.LegacyJavascriptBindingEnabled = true; 调 ...
- 【shell学习笔记】curl命令总结
2014-12-16 20:34 文思海辉 =========== CURL命令总结 1. 下载 curl -o [文件名称] www.baidu.com 2. 显示 HTTP request头信息 ...
- Revit API遍历系统族布置喷头
系统族可以通过内参遍历,遍历出来是个FamilySymbol喷头属于系统族,但不能通过NewDuct();类似这样的方法布置.必须使用 NewFamilyInstance() ); ...
- 委托、Lambda表达式、事件系列01,委托是什么,委托的基本用法,委托的Method和Target属性
委托是一个类. namespace ConsoleApplication1 { internal delegate void MyDelegate(int val); class Program { ...
- sql语句练习题
6.Mysql不要用top用limit 在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢? 查找时Mysql不能用top,反正我用不了,查了下可以用limit来替换. 比 ...