学习编程分形有助于清楚地了解某些编程问题吗?编程分形
编程分形
回答
从我记得你会得到一个很好的手柄上的递归,如果没有别的......也许有点位级编程以及...
任何一种编程经验是有用的。所以是的。
:特别适用:
- 数学问题
- 基本算法
- ,当然分编程
这将可能给你实现数学公式练习。
一些分形是显式递归的好例子;如果你对这个概念感到困难,那么他们可能是一个很好的工作问题。你可以从“龟图形”风格分形路径开始,如希尔伯特曲线或经典的“雪花”分形。
许多分形生成方法使用重型数字运算(例如Mandelbrot和Julia集合)。数字运算本身就是一个领域,调整分形生成器以尽可能快地运行可能是优化中的一个很好的练习。
我不认为编程分形将教你什么特别。根据分形,我想它可能会教你一些关于数学或分形的一般信息。
但是,我认为分形作为编程的入门很有趣,而初学者/学生往往对结果着迷,无论是更多的图形分形如mandelbrot或茱莉亚集合,还是更易于理解的L-系统。
当然,如果你是新手编程,它也希望能够教你很多关于编程的知识。如果没有别的,分形是有趣的看看。
当我还是一名本科生时,我们使用分形图来推动我们的工作。它可以快速获得相当大的计算量,因此可以使用多个CPU来完成这项工作,这样可以显着提高效率。
所以,随着递归,我会说它有助于学习如何在并行处理器之间平衡CPU负载。
...或者如果设备不可用,它可能会教你禅样耐心。 :)
分形让我想起了复数和branch-points。我想,这是否是一件好事是一个意见。 :-)
分形编程将向您介绍递归,迭代,图形编程概念,图像处理和用户界面设计。从数学的角度来看,您将学习几何,复数,Mobius变换(Kleinian分形),仿射变换(IFS分形),根发现方法(牛顿分形)。
最重要的是,您可以看到您的努力会产生奇怪和不寻常的图像。
如果您是初学者,此类活动肯定会帮助您提高技能。除了根据分形类型和设置可能会给你一些特定的技能或知识类的目标是编程分形可视化:
- 与图形,图像处理工作;
- 理解递归和递归 结构;
- 优化技术;
- 低级程序优化;
- 理解如何计算机的运行 (例如为何分辨率将是 通常限于 - >浮点 精度和误差积累);
- 并行编程;
- 一些数学改进和 扩展您的兴趣范围;
- 了解各种技术 (例如,您可以code Mandelbrot set在PixelBender这是 真的很快,因为可能会在 GPU上执行);
- 了解复杂压缩算法(例如某种分形 压缩);
- 创造力(例如,你发明自己的 分形集着色算法);
- 更多别的:)
这确实是一个多才多艺和有趣的领域,很多事情探索和学习。我用来绘制分形很多:)
好主意!我认为编码分形是一个伟大的“练习”(研究)大小的程序。它有这样一些很好的功能:通常你不需要太多的第三方代码,它们可以在相当短的时间内(和复杂性)实现,并且你最终还能看到一些很好的东西,这也验证了你的工作。
此外,在数学和数值算法的实现方面都存在大量的基本问题,如果你这样做,你会碰到这些问题。
从一个基本的Mandelbrot集合生成器那样简单的事情,你可以像评论者提到的那样分支出各种各样的问题。尽管如此,你仍然可以学习优化技术(为什么我的发生器很慢)和数值问题(为什么我不能在这里放大),而且如果你想要一点色彩理论(什么是L a b *空间无论如何)和其他零碎。
玩得开心!
分形是一个非常智力上有趣的话题,甚至最简单的实现也会让你学习复数数学,图形生成,缩放图像和一般编程。
- 1. C++图形编程
- 2. X11图形编程字体
- 3. R在图形上编程
- 4. 图形编程语言
- 5. “低级”3D图形编程
- 6. 形状绘制编程
- 7. 编程图形工具链
- 8. 形式不提交编程
- 9. R编程图形命令
- 10. 图形编辑器编程挑战
- 11. 在D3中以编程方式将形状分配给节点
- 12. win32程序集编程图形卡
- 13. Rails的回形针,编辑的形式是,file_field未分配
- 14. 函数式编程语言是否适合图形编程?
- 15. 通过OpenGL的图形编程无需windows编程
- 16. 用于箱形图编程的R编程
- 17. 编程WHERE部分SQL
- 18. C程序分步编译
- 19. C编程:间隔分区
- 20. Android - 如何编程得分?
- 21. C编程问题 - 分支
- 22. JGAP遗传编程 - 分类
- 23. 分布式python编程
- 24. erlang分布式编程
- 25. 编程和数值分析
- 26. 分配HiddenField值编程
- 27. Axapta的:编程切换记录形式
- 28. Linux/Unix下的Haskell图形编程
- 29. 用MonoTouch编程绘制矩形
- 30. 了解低级图形编程
有没有必要使用递归来绘制分形。我知道的大多数分形,如Mandelbrot集使用简单的迭代。 – recursive 2009-01-14 21:01:05
即使他们完成递归,它也是递归的限制,无论如何都会重构迭代。或者至少我见过的每个例子都有明确的限制。 – EBGreen 2009-01-14 21:09:57
递归如何处理轨道和固定点?IIRC证明了对于所有N> = 1,在Mandelbrot集合中存在长度为N的循环非终止轨道。 – Jimmy 2009-01-14 21:17:31