混沌分形之马丁(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的定义及相关软件见:混沌与分形

点集图形:

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

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值