我不記得從什么地方看到的這種分形圖形生成方式,再到網上找竟然一時沒查到任何相關資料。沒關系,總之這種圖形也很漂亮多變,並且其算法比較簡單。只是我最后生成的圖像有點瘮人,密集恐懼症患者慎入。
相關代碼如下:
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的定義及相關軟件見:混沌與分形
點集圖形:
以此算法生成的圖像如下:
我想這幾幅圖有密集恐懼症的人一定看不下去,而我看到它時總會想到一種東西叫“蓮蓬乳”。