混沌分形之朱利亚集(JuliaSet)
朱利亚集合是一个在复平面上形成分形的点的集合。以法国数学家加斯顿·朱利亚(Gaston Julia)的名字命名。我想任何一个有关分形的资料都不会放过曼德勃罗集和朱利亚集。这里将以点集的方式生成出朱利亚集的图形。
关于基类FractalEquation的定义及相关软件见:混沌与分形
class JuliaSet : public FractalEquation
{
public:
JuliaSet()
{
m_StartX = 0.0f;
m_StartY = 0.0f;
m_StartZ = 0.0f;
m_ParamA = -0.75f;
m_ParamB = 0.01f;
}
void IterateValue(float x, float y, float z, float& outX, float& outY, float& outZ) const
{
float wx, wy;
float r;
float theta;
float rnd = yf_rand_real(1.0f);
wx = x-m_ParamA;
wy = y-m_ParamB;
if(wx == 0)
theta = PI/2;
if(wx > 0)
theta = atanf(wy/wx);
if(wx < 0)
theta = PI-atanf(wy/wx);
theta = theta/2;
r = sqrtf(wx*wx+wy*wy);
if(rnd < 0.5f)
r = sqrt(r);
else
r = -sqrt(r);
outX = r*cos(theta);
outY = r*sin(theta);
outZ = z;
}
bool IsValidParamA() const {return true;}
bool IsValidParamB() const {return true;}
};
算法中使用了两个参数,修改参数值可以看到不同的图形
最后发两幅相关图像:
Mandelbrot 图像
Julia Sets图像
……
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?