论坛交流
首页办公自动化| 网页制作| 平面设计| 动画制作| 数据库开发| 程序设计| 全部视频教程
应用视频: Windows | Word2007 | Excel2007 | PowerPoint2007 | Dreamweaver 8 | Fireworks 8 | Flash 8 | Photoshop cs | CorelDraw 12
编程视频: C语言视频教程 | HTML | Div+Css布局 | Javascript | Access数据库 | Asp | Sql Server数据库Asp.net  | Flash AS
当前位置 > 文字教程 > C语言程序设计教程
Tag:新手,函数,指针,数据类型,对象,Turbo,入门,运算符,数组,结构,二级,,tc,游戏,试题,问答,编译,视频教程

一个分形图形

文章类别:C语言程序设计 | 发表日期:2008-9-24 14:43:26

    和混沌密切相关的另一门学科是分形学。分形是由IBM公司的科学家曼德勃罗特在1975年提出的,作为计算机图形学的一个分支,用分形的方法生成的图像向人们展示了在简单的数学模型中蕴涵的内在美、对称性和复杂性。下面的第一幅图被称作曼德勃罗特集,其余几幅分别是对它的某个细节放大得到的。
    曼德勃罗特集的数学模型非常简单。假设有复数Z和μ,用下式迭代计算:Z=Z2+μ,由于μ的取值不同,经过若干次数迭代以后Z的幅值可能趋向无穷,也可能保持有界,曼德勃罗特集就是那些使Z保持有界的μ的集合,把μ在复平面上的分布作成图像,就像上面演示的那样具有极其复杂的结构。
下面的程序用TC2.0编写, 假设屏幕的分辨率为640×480。
#include <graphics.h>
main(){
int nThre=100; /* 其中nThre代表设置的门限值,当迭代后Z的幅值的平方大于nThre则认为趋于无穷*/
int xCord,yCord,nColor,nTimes; /*xCord和yCord分别代表平面上的点的坐标位置,nColor代表作图时所使用的颜色,nTimes表示迭代的次数 */
float reP,rePmin=-1.5,rePmax=0.75; /*reP表示由平面上一点所代表的μ值的实部,rePmax、rePmin分别代表μ值实部可取的最大值和最小值*/
float imP,imPmin=-1.5,imPmax=1.5; /*imP、imPmax和imPmin分别代表μ的虚部及其容许的最大值和最小值*/
float reZ,imZ,tmpReZ,deltImP,deltReP,absZ; 
/*reZ和imZ分别代表Z值的实部和虚部,deltImP、deltReP表示每一个象素的代表的实部和虚部值的大小,absZ代表Z值的幅值 */ 
int GraphDriver=DETECT,GraphMode; /*初始化图形显示*/
initgraph(&GraphDriver,&GraphMode,“ ");
deltReP=(rePmax-rePmin)/640; /*计算屏幕上一个像素表*/
deltImP=(imPmax-imPmin)/480; /*和虚部值的大小示的 */
for(xCord=1;xCord<641;xCord++)
for (yCord=1;yCord<481;yCord++){
reP=rePmin+deltReP*xCord; /*计算屏幕上一点所*/
imP=imPmin+deltImP*yCord;/*代表的μ值大小*/
reZ=0; imZ=0;
for(nTimes=0;nTimes<160;nTimes++){
tmpReZ=reZ*reZ-imZ*imZ+reP; /*计算迭代后的Z*/
imZ=2*reZ*imZ+imP;/*值及其幅值大小*/
reZ=tmpReZ;absZ=reZ*reZ+imZ*imZ;
if (absZ>nThre){nColor=nTimes/10;break;}
/*假如幅值的平方大于门限值终止迭代*/
nColor=0;}
putpixel(xCord,yCord,nColor); }/*用指定的颜色作点*/
getch();
}
    上面的程序中,可以通过改变imPmin、imPmax以及rePmin与rePmax的值来对图像的局部细节进行放大,从而可以观察到更加精美复杂的图像,领悟分形图像的神韵。
    曼德勃罗特集是人们发现的最早的分形图形之一,也是人们研究最多的分形图形之一,今年的菲尔兹奖(数学界的最高奖)得主麦克马兰就是因为在曼德勃罗特集研究中的成绩而获此殊荣的。这些年关于分形的研究已经渗透到科学领域的各个学科,在计算机领域利用分形的方法来对自然景物进行逼真的模拟是一个很具挑战性的研究方向。      

上一篇:{实例}通用数制转换程序 人气:7837
下一篇:{实例}用画线函数作出的图案 人气:6930
视频教程列表
文章教程搜索
 
C语言程序设计推荐教程
C语言程序设计热门教程
看全部视频教程
购买方式/价格
购买视频教程: 咨询客服
tel:15972130058