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

混沌分形之马丁(Martin)迭代

      我不记得从什么地方看到的这种分形图形生成方式,再到网上找竟然一时没查到任何相关资料。没关系,总之这种图形也很漂亮多变,并且其算法比较简单。只是我最后生成的图像有点瘆人,密集恐惧症患者慎入。

相关代码如下:

复制代码
class MartinIterate : public FractalEquation
{
public:
    MartinIterate()
    {
        m_StartX = 1.0f;
        m_StartY = 1.0f;
        m_StartZ = 0.0f;

        m_ParamA = 0.68f;
        m_ParamB = 0.75f;
        m_ParamC = 0.83f;
    }

    void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
    {
        if (x > FLT_EPSILON)
        {
            outX = y - sqrtf(fabsf(m_ParamB*x - m_ParamC));
        }
        else if (x < -FLT_EPSILON)
        {
            outX = y + sqrtf(fabsf(m_ParamB*x - m_ParamC));
        }
        else
        {
            outX = y;
        }
        
        outY = m_ParamA - x;

        outZ = z;
    }

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

    bool Is3D() const {return false;}
};
复制代码

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

点集图形:

以此算法生成的图像如下:

我想这几幅图有密集恐惧症的人一定看不下去,而我看到它时总会想到一种东西叫“莲蓬乳”。

posted on   叶飞影  阅读(4346)  评论(3编辑  收藏  举报
编辑推荐:
· 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

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