最近看了很多与混沌相关的知识,并写了若干小软件.混沌现象是个有意思的东西,同时混沌也能够生成许多有意思的图形.混沌学的现代研究使人们渐渐明白,十分简单的数学方程完全可以模拟系统如瀑布一样剧烈的行为。输入端微小的差别能够迅速放大到输出端,变成压倒一切的差别,这种现象被称为“对初始条件的敏感性”。

混沌现象其基本含义可以概括为:聚散有法,周行而不殆,回复而不闭。意思是说混沌轨道的运动完全受规律支配,但相空间中轨道运动不会中止,在有限空间中永远运动着,不相交也不闭合。浑沌运动表观上是无序的,产生了类随机性,也称内在随机性。混沌系统具有三个关键要素:一是对初始条件的敏感依赖性;二是临界水平,这里是非线性事件的发生点;三是分形维,它表明有序和无序的统一。混沌系统经常是自反馈系统,出来的东西会回去经过变换再出来,循环往复,没完没了,任何初始值的微小差别都会按指数放大,因此导致系统内在地不可长期预测。

这一节将先展示下混沌点集所生成的图形.这是一个生成混沌离散点集图形的DEMO,里面含有多个不同方程生成的混沌图形.在这个DEMO中,会看到由点集生成的看得出规律的及看不出规律的图形.

下载地址为:http://files.cnblogs.com/WhyEngine/chaos.7z

软件中有两种视口显示模式,三维和二维的.键盘O用于二者间的切换.
鼠标右键用于控制视口.

键盘G用于是否显示网格的切换

-------------------------------------------------------------

在这种离散点集的混沌图形中,使用迭代的方法生成顶点数据: 
在中学课本中我们学过,一个一元函数,通常可以表示为: Y=f(x) 这里X是自变量,Y是因变量。
例如: Y=3X+1,如果X=1,那么Y=4;如果X=4,那么Y=13;总之,如果X被确定,那么相应的Y也被确定。

我们用一个抽象的符号F,来表示Y遵循X变化的因果关系。废话连篇的解释是:数字Y随数字X的变化而变化,Y由X来决定,决定的依据是“关系”F。

如果我们利用某个关系函数,比如Y=F(X),代入一个X算出一个Y,又将Y作为新的X再次计算下一个Y………如此不断,这种方法在数学上称为迭代,具体的表达式是: Xn =F(X n-1 ),n=1,2,3……..

学过程序的人一定知道"费波那齐数列",它算是比较典型的Xn =F(X n-1 )方程的例子。不过这种方程不是收敛的,所以它的图形几下就会爆表。

OK,那先帖下我写的有关这种离散方程对象的基类定义代码:

 #define SET_GET_FLOAT_PROPERTY(name) \
void Set##name##(float v)\
{\
m_##name## = v;\
}\
float Get##name##() const\
{\
return m_##name##;\
} #define PI 3.14159265f // -------------------------------------------------------------------------------------- class DiscreteEquation
{
public:
DiscreteEquation()
{
m_StartX = 0.0f;
m_StartY = 0.0f; m_ParamA = 0.0f;
m_ParamB = 0.0f;
m_ParamC = 0.0f;
m_ParamD = 0.0f;
m_ParamE = 0.0f;
} // 求迭代值
virtual void IterateValue(float y, float z, float& outY, float& outZ) const = NULL; // 计算点集的Z轴坐标
static void CalculatePointsZ(void* curveVerticesPtr, unsigned int stride, unsigned int count, float minZ, float maxZ)
{
char* zPtr = (char*)curveVerticesPtr + *sizeof(float);
float zStep = (maxZ - minZ)/(count - ); for (unsigned int i = ; i < count; i++)
{
*(float*)zPtr = minZ + i*zStep;
zPtr += stride;
}
} // 计算点集的Y轴与X轴坐标
virtual void CalculatePointsXY(void* curveVerticesPtr, unsigned int stride, unsigned int count)
{
char* xPtr = (char*)curveVerticesPtr;
char* yPtr = (char*)curveVerticesPtr + sizeof(float); float y, x;
float nx, ny; x = m_StartX;
y = m_StartY; for (unsigned int i = ; i < count; i++)
{
*(float*)xPtr = x;
*(float*)yPtr = y; IterateValue(x, y, nx, ny); x = nx;
y = ny; xPtr += stride;
yPtr += stride;
}
} SET_GET_FLOAT_PROPERTY(StartX);
SET_GET_FLOAT_PROPERTY(StartY); SET_GET_FLOAT_PROPERTY(ParamA);
SET_GET_FLOAT_PROPERTY(ParamB);
SET_GET_FLOAT_PROPERTY(ParamC);
SET_GET_FLOAT_PROPERTY(ParamD);
SET_GET_FLOAT_PROPERTY(ParamE); virtual bool IsValidParamA() const {return false;}
virtual bool IsValidParamB() const {return false;}
virtual bool IsValidParamC() const {return false;}
virtual bool IsValidParamD() const {return false;}
virtual bool IsValidParamE() const {return false;} protected:
float m_StartX;
float m_StartY; float m_ParamA;
float m_ParamB;
float m_ParamC;
float m_ParamD;
float m_ParamE;
};

每一种混沌点集图形,在程序中都是DiscreteEquation对象的子类.

目前,我已经实现了以下几种混沌方程,将在后来的章节中一一介绍:

(1)混沌数学之logistic模型

(2)混沌数学之二维logistic模型

(3)混沌数学之Baker模型

(4)混沌数学之CircuitChaotic(二维离散电路混沌系统)

(5)混沌数学之Arnold模型

(6)混沌数学之Standard模型

(7)混沌数学之Feigenbaum模型

(8)混沌数学之生物动力学混沌模型

(9)混沌数学之Kent模型

(10)混沌数学之帐篷模型

(11)混沌数学之ASin模型

(12)混沌数学之Henon模型

混沌数学之离散点集图形DEMO的更多相关文章

  1. 混沌数学之CircuitChaotic(二维离散电路混沌系统)

    相关软件参见:混沌数学之离散点集图形DEMO 相关代码: // http://wenku.baidu.com/link?url=yg_gE7LUXCg2mXRp-ZZdfRXXIkcNj8YOhvN7 ...

  2. 混沌数学之logistic模型

    logistic回归又称logistic回归分析,主要在流行病学中应用较多,比较常用的情形是探索某疾病的危险因素,根据危险因素预测某疾病发生的概率. 相关DEMO参见:混沌数学之离散点集图形DEMO ...

  3. 混沌数学之ASin模型

    相关软件:混沌数学之离散点集图形DEMO 相关代码: class ASinEquation : public DiscreteEquation { public: ASinEquation() { m ...

  4. 混沌数学之Kent模型

    相关软件:混沌数学之离散点集图形DEMO 相关代码: // http://wenku.baidu.com/view/7c6f4a000740be1e650e9a75.html // 肯特映射 clas ...

  5. 混沌数学之Feigenbaum模型

          1975年,物理学家米切尔·费根鲍姆(Mitchell Feigenbaum)发现,一个可用实验加以测 量的特殊数与每个周期倍化级联相联系.这个数大约是4.669,它与π并列成为似乎在数学 ...

  6. 混沌数学之Standard模型

    相关软件混沌数学之离散点集图形DEMO 相关代码: class StandardEquation : public DiscreteEquation { public: StandardEquatio ...

  7. 混沌数学之Arnold模型

    相关软件混沌数学之离散点集图形DEMO 相关代码: class ArnoldEquation : public DiscreteEquation { public: ArnoldEquation() ...

  8. 混沌数学之Baker模型

    相关DEMO参见:混沌数学之离散点集图形DEMO 相关代码: // http://wenku.baidu.com/view/ac9b57ea172ded630b1cb65b.html class Ba ...

  9. 混沌数学之Henon模型

    相关DEMO参见:混沌数学之离散点集图形DEMO 相关代码: // http://wenku.baidu.com/view/d51372a60029bd64783e2cc0.html?re=view ...

随机推荐

  1. ASL测试 课题测试博客

    已知线性表具有元素{5,13,19,21,37,56,64,75,80,88,92},如果使用折半查找法,ASL是多少? 知识点1: 折半查找法:折半查找,又称作二分查找.这个查找的算法的特点,要求数 ...

  2. TCP可靠传输及流量控制实现原理

    一.为什么TCP是可靠传输? 1. 停止等待协议 通过确认与超时重传机制实现可靠传输 在发送完一个分组后,必须暂时保留已发送的分组的副本. 分组和确认分组都必须进行编号. 超时计时器的重传时间应当比数 ...

  3. Linux 的文件权限与目录配置

    用户和用户组 文件所有者 (owner) 用户组概念 (group) 其他人概念 (others) Linux文件权限概念 1. Linux文件属性 要了解Linux文件属性,那么有个重要的命令必须提 ...

  4. python io 模块之 open() 方法(好久没写博客了)

    io.open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True),打开file ...

  5. 决策树(CART)

    CART算法全称是分类回归算法,(Classification And Regression Tree),他与ID3.C4.5的不同在于: 1.既可以处理分类问题又可以处理回归问题 2.使用基尼系数作 ...

  6. 常用SQL脚本记录一

    20.SUM()和 列+ 统计结果时:如果列里有一行为null,SUM函数会忽略它:如果+,则结果集也为NULL了 19 SUBSTRING (expression,startIndex, endIn ...

  7. WinlogonHack获取系统密码

    实验环境: win03 sp1 Gina.dll与Msgina.dll Gina.dll在NT/2000中交互式的登陆支持是由WinLogon调用Gina.dll实现的,Gina.dll提供了一个交互 ...

  8. 【JavaScript代码实现四】获取和设置 cookie

    // 创建cookie function setCookie(name, value, expires, path, domain, secure) { var cookieText = encode ...

  9. GIT(3)----问题汇总

    1.git pull出现的合并问题: Please enter a commit message to explain why this merge is necessary,especially i ...

  10. mysql+mycat分片环境部署

    说明: 1.操作系统:64位CentOS Linux release 7.2.1511 (Core) 2.jdk版本:1.8.0_121 3.mysql版本: 5.7.17 4.两台mysql服务器: ...