一篇挺有意思的**《聆听混沌的声音》(转)

[复制链接]
4985|4
 楼主| mohanwei 发表于 2007-1-28 19:25 | 显示全部楼层 |阅读模式
fm, tc, se, Sound, os
今天整理硬盘,看到一篇挺有意思的文章《聆听混沌的声音》,忍不住做了一个<br />实验,实验结果和作者描述的差不多,呵呵。<br /><br />以下是原文以及源程序,后面还有一个压缩包,内有源程序和可执行文件。如果<br />读者手头没有编译器,直接运行里面的程序就可以了(你得保证你的机器里有<br />一个峰鸣器)。<br /><br /><br />/**********************************************************************<br />聆听混沌的声音<br /><br />本世纪70年代初,美国普林斯顿大学的生态学家R·May在研究昆虫群体繁殖规律时提出<br />一个著名的模型:&nbsp;χ[n+1]=k*χ[n]*(1-χ[n])其中χ[n]表示第n代群体的数目。<br />当给定一个初始的χ[0]值,然后不停地迭代,人们发现随着k值的不同,得到的序列χn<br />有许多有趣的现象。当k值介于0与1之间时,χ[n]经过一定次数的迭代后都趋于0。<br />当k值介于1和3之间时趋于1/k,当k值大于3时,经过一定次数的迭代后χ[n]在2个值<br />之间交替变化,k值增加到3.449附近时,交替变化值又变为4个。继续增加k值,χ[n]<br />交替变化的值的个数依4→8→16→32的次序迅速加倍,终于一片混沌。但当k值在3.835<br />附近时,经过一定次数的迭代后,χ[n]非常简单地在3个值之间交替变化,接着又迅速<br />依3→6→12的次序迅速增长。如此反复,在简单的方程中隐藏着令人惊奇的复杂性。<br />χ[n]随k的变化情况如下图所示:<br />为了体现这种复杂之中的无穷奥妙,下面这个用TC2.0编写的小程序用χ[n]大小来控制<br />PC喇叭的发音频率,设定不同的k值,我们就可以聆听到混沌的声音。<br /><br />执行下面的小程序时,k值就相当于一个“调音旋钮”。当将k值设定在1与3之间时,<br />喇叭里传出的只有一个音调,重复又烦人。当k值稍稍大于3时,便开始有了韵律:<br />so-mi-so-mi…。k值增加到3.449时,变成了so-fa-la-mi-so-fa-la-mi…,<br />再增加k值,韵律更加复杂,终于成了现代抽象派作曲家的音乐作品。但是韵律并不是<br />随着k值的增加无限地复杂下去。在k值增加到3.835时,音调又变成了<br />mi-so-ti-mi-so-ti…,再增加k值又迅速地变得更加复杂。<br />不停地改变k值,仔细聆听,会听到混沌中的无限奥妙。(甘肃梁昌霖)<br />**********************************************************************/<br /><br />/**********************************************************************<br />程序名称:聆听混沌的声音<br />平&nbsp;&nbsp;&nbsp;&nbsp;台:TC++&nbsp;3.0<br />作&nbsp;&nbsp;&nbsp;&nbsp;者:AMO<br />Email&nbsp;&nbsp;&nbsp;:amo73@126.com<br />日&nbsp;&nbsp;&nbsp;&nbsp;期:2007-1-27<br />备&nbsp;&nbsp;&nbsp;&nbsp;注:这是一个很有趣的小程序。<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;参考“梁昌霖”(先生/女士?)发表的程序,做了很多改进。<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;AMO不打算拥有程序版权,欢迎大家自由传播^_^<br />**********************************************************************/<br />#include&nbsp;&ltdos.h&gt<br />#include&nbsp;&ltstdio.h&gt<br />#include&nbsp;&ltconio.h&gt<br />main()<br />{<br />&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;fMin=20,fMax=16000;&nbsp;/*fMin代表最低频率,fMax代表最高频率*/<br />&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;fDis,i;&nbsp;/*fDis代表最高频率和最低频率之间的差值,i用于循环记数*/<br />&nbsp;&nbsp;&nbsp;&nbsp;float&nbsp;x=0.1,k;&nbsp;/*x代表x[n]的大小,设定其初始值为0.1,即x[0]=0.1*/<br />&nbsp;&nbsp;&nbsp;&nbsp;char&nbsp;ch;<br />&nbsp;&nbsp;&nbsp;&nbsp;fDis=fMax-fMin;<br />&nbsp;&nbsp;&nbsp;&nbsp;clrscr();<br />&nbsp;&nbsp;&nbsp;&nbsp;while(1)<br />&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf(&quot;Please&nbsp;input&nbsp;The&nbsp;value&nbsp;of&nbsp;k(1-4.0)
&quot;);&nbsp;/*输入k值*/<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf(&quot;If&nbsp;you&nbsp;want&nbsp;to&nbsp;quit,Please&nbsp;input:0
&quot;);&nbsp;/*如果k=0退出*/<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;scanf(&quot;%f&quot;,&k);<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(k==0)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;else&nbsp;if((k&lt1)||(k&gt4.0))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf(&quot;The&nbsp;number&nbsp;must&nbsp;be:&nbsp;1&ltk&lt4

&quot;);<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;continue;//输入有误,继续输入。<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for(i=1;i&lt100;i++)&nbsp;/*去掉开始的100个点*/<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;x=k*x*(1-x);<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(i=1;i&lt100;i++)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;x=k*x*(1-x);&nbsp;/*计算x的值*/<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sound(x*fDis+20);&nbsp;/*用x的值控制PC喇叭的发音频率*/<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;delay(1000);<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(kbhit())//kbhit()检测是否有按键事件,如果没有按键,则返回0;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ch=getch();//读取按键值<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;switch(ch)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;case&nbsp;27:&nbsp;&nbsp;&nbsp;&nbsp;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;nosound();//关闭声音<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return(0);//ESC退出<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;nosound();//关闭声音<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;clrscr();//清屏<br />&nbsp;&nbsp;&nbsp;&nbsp;}<br />&nbsp;&nbsp;&nbsp;&nbsp;nosound();<br />&nbsp;&nbsp;&nbsp;&nbsp;return(0);<br />}<br /><br /><br />以下是程序:<br /><br />http://pdf.18ic.com/upload/2007-1/28/2007128193243.zip<br /> 相关链接:<a href='http://pdf.18ic.com/upload/2007-1/28/2007128193243.zip'>http://pdf.18ic.com/upload/2007-1/28/2007128193243.zip</a>
bsbjx 发表于 2007-1-29 14:10 | 显示全部楼层

混沌???

O担心人也跟着混沌了.
chunyang 发表于 2007-1-29 14:28 | 显示全部楼层

呵呵,哪天试试

  
huangqi412 发表于 2007-10-14 16:14 | 显示全部楼层

呵呵,试试

woshansi 发表于 2014-1-28 10:02 | 显示全部楼层
想玩的时候我一定试试
您需要登录后才可以回帖 登录 | 注册

本版积分规则

177

主题

9317

帖子

24

粉丝
快速回复 在线客服 返回列表 返回顶部