随笔 - 373  文章 - 1  评论 - 771  阅读 - 137万

混沌分形之逻辑斯蒂(Logistic)映射系统

      前几天,有个同事看到我生成的一幅逻辑斯蒂分岔图像后,问我:“这是咪咪吗?”我回答:“淫者见淫。”好吧,这里将生成几种分岔映射图形,包括逻辑斯蒂映射系统,正弦映射系统和曼德勃罗映射系统。实际上这几种图形算不上分形,只不过它与我写的其他分形对象使用相同的基类,所以也将其列入混沌分形的范畴。

      关于基类FractalEquation的定义及相关软件见:混沌与分形

(1)逻辑斯蒂映射系统

复制代码
// 逻辑斯蒂映射系统
class LogisticMap : public FractalEquation
{
public:
    LogisticMap()
    {
        m_StartX = 0.0f;
        m_StartY = 0.0f;
        m_StartZ = 0.0f;

        m_ParamA = 0.0f;
        m_ParamB = 4.0f;

        m_nIterateCount = 100;
    }

    void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
    {
        float R = (float)rand()/RAND_MAX;
        float k = m_ParamA + (m_ParamB - m_ParamA) * R;
        outX = R*4.0f;

        outY = (float)rand()/RAND_MAX;
        for (int i = 0; i < m_nIterateCount; i++)
        {
            outY = k*outY*(1-outY);
        }
        outY *= 2;

        outZ = z;
    }

    bool IsValidParamA() const {return true;}
    bool IsValidParamB() const {return true;}

private:
    int m_nIterateCount;
};
复制代码

调节下参数后的图形:

(2)正弦映射系统

复制代码
// 正弦映射系统
class SinMap : public FractalEquation
{
public:
    SinMap()
    {
        m_StartX = 0.0f;
        m_StartY = 0.0f;
        m_StartZ = 0.0f;

        m_ParamA = -2*PI;
        m_ParamB = 2*PI;

        m_nIterateCount = 64;
    }

    void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
    {
        float R = (float)rand()/RAND_MAX;
        float k = m_ParamA + (m_ParamB - m_ParamA) * R;
        outX = R*4.0f;

        outY = (float)rand()/RAND_MAX;
        for (int i = 0; i < m_nIterateCount; i++)
        {
            outY = k*sinf(outY);
        }

        outY *= 0.5f;

        outZ = z;
    }

    bool IsValidParamA() const {return true;}
    bool IsValidParamB() const {return true;}

private:
    int m_nIterateCount;
};
复制代码

(3)曼德勃罗映射系统

复制代码
// 曼德勃罗映射系统
class MandelbrotMap : public FractalEquation
{
public:
    MandelbrotMap()
    {
        m_StartX = 0.0f;
        m_StartY = 0.0f;
        m_StartZ = 0.0f;

        m_ParamA = -2.0f;
        m_ParamB = 0.0f;

        m_nIterateCount = 64;
    }

    void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
    {
        float R = (float)rand()/RAND_MAX;
        float k = m_ParamA + (m_ParamB - m_ParamA) * R;
        outX = R*4.0f;

        outY = (float)rand()/RAND_MAX;
        for (int i = 0; i < m_nIterateCount; i++)
        {
            outY = outY*outY + k;
        }

        outZ = z;
    }

    bool IsValidParamA() const {return true;}
    bool IsValidParamB() const {return true;}

private:
    int m_nIterateCount;
};
复制代码

最后发下被我同事当成MM的逻辑斯蒂分岔图像:

 之前我还写过一篇关于逻辑斯蒂的文章:混沌数学之logistic模型

posted on   叶飞影  阅读(13802)  评论(6编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示