- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
蟻群算法的原理以及实现源代码
蚁群算法ACO(ant colony optimization)的原理以及实现源代码 By Minidxer | February 1, 2008 之前说的算法基本上都比较枯燥的(废话,算法都很枯燥……),这次要介绍的蚁群算法(Ant Colony Algorithm)却是一种源于自然现象的算法,也是一种 meta heuristic,即与具体问题关系不大的优化算法,也就是它是一种用来在图中寻找优化路径的机率型技术。Marco Dorigo于1992年在他的博士论文中引入,其灵感来源于蚂蚁在寻找食物过程中发现路径的行为。 小小的蚂蚁总是能够找到食物,他们具有什么样的智能呢?设想,如果我们要为蚂蚁设计一个人工智能的程序,那么这个程序要多么复杂呢?首先,你要让蚂蚁能够避开障碍物,就必须根据适当的地形给它编进指令让他们能够巧妙的避开障碍物,其次,要让蚂蚁找到食物,就需要让他们遍历空间上的所有点;再次,如果要让蚂蚁找到最短的路径,那么需要计算所有可能的路径并且比较它们的大小,而且更重要的是,你要小心翼翼的编程,因为程序的错误也许会让你前功尽弃。这是多么不可思议的程序!太复杂了,恐怕没人能够完成这样繁琐冗余的程序。 为什么这么简单的程序会让蚂蚁干这样复杂的事情?答案是:简单规则的涌现。事实上,每只蚂蚁并不是像我们想象的需要知道整个世界的信息,他们其实只关心很小范围内的眼前信息,而且根据这些局部信息利用几条简单的规则进行决策,这样,在蚁群这个集体里,复杂性的行为就会凸现出来。这就是人工生命、复杂性科学解释的规律! 下面就是实现如此复杂性的七条简单规则: 1、范围:蚂蚁观察到的范围是一个方格世界,蚂蚁有一个参数为速度半径(一般是3),那么它能观察到的范围就是3*3个方格世界,并且能移动的距离也在这个范围之内。2、环境:蚂蚁所在的环境是一个虚拟的世界,其中有障碍物,有别的蚂蚁,还有信息素,信息素有两种,一种是找到食物的蚂蚁洒下的食物信息素,一种是找到窝的蚂蚁洒下的窝的信息素。每个蚂蚁都仅仅能感知它范围内的环境信息。环境以一定的速率让信息素消失。3、觅食规则:在每只蚂蚁能感知的范围内寻找是否有食物,如果有就直接过去。否则看是否有信息素,并且比较在能感知的范围内哪一点的信息素最多,这样,它就朝信息素多的地方走,并且每只蚂蚁多会以小概率犯错误,从而并不是往信息素最多的点移动。蚂蚁找窝的规则和上面一样,只不过它对窝的信息素做出反应,而对食物信息素没反应。4、移动规则: 每只蚂蚁都朝向信息素最多的方向移,并且,当周围没有信息素指引的时候,蚂蚁会按照自己原来运动的方向惯性的运动下去,并且,在运动的方向有一个随机的小的扰动。为了防止蚂蚁原地转圈,它会记住最近刚走过了哪些点,如果发现要走的下一点已经在最近走过了,它就会尽量避开。5、避障规则:如果蚂蚁要移动的方向有障碍物挡住,它会随机的选择另一个方向,并且有信息素指引的话,它会按照觅食的规则行为。 7、播撒信息素规则:每只蚂蚁在刚找到食物或者窝的时候撒发的信息素最多,并随着它走远的距离,播撒的信息素越来越少。 下面的程序开始运行之后,蚂蚁们开始从窝里出动了,寻找食物;他们会顺着屏幕爬满整个画面,直到找到食物再返回窝。 其中,‘F’点表示食物,‘H’表示窝,白色块表示障碍物,‘+’就是蚂蚁了。 参数说明:最大信息素:蚂蚁在一开始拥有的信息素总量,越大表示程序在较长一段时间能够存在信息素。信息素消减的速度:随着时间的流逝,已经存在于世界上的信息素会消减,这个数值越大,那么消减的越快。错误概率表示这个蚂蚁不往信息素最大的区域走的概率,越大则表示这个蚂蚁越有创新性。速度半径表示蚂蚁一次能走的最大长度,也表示这个蚂蚁的感知范围。记忆能力表示蚂蚁能记住多少个刚刚走过点的坐标,这个值避免了蚂蚁在本地打转,停滞不前。而这个值越大那么整个系统运行速度就慢,越小则蚂蚁越容易原地转圈。 源代码如下(不同编译器可能需做一定修改): /*ant.c*/ #define SPACE 0x20 #define ESC 0x1b #define ANT_CHAR_EMPTY + #define ANT_CHAR_FOOD 153 #define HOME_CHAR H #define FOOD_CHAR F #define FOOD_CHAR2 f #define FOOD_HOME_COLOR 12 #define BLOCK_CHAR 177 #define MAX_ANT 50 #define INI_SPEED 3 #define MAXX 80 #define MAXY 23 #define MAX_FOOD 10000 #define TARGET_FOOD 200 #de
您可能关注的文档
- 螺旋藻知識讲解必看.doc
- 融資与财务分析挑战bei.doc
- 螺旋角度不同的螺旋折流板換热器壳程传热性能研究.doc
- 螺旋起重器設计.doc
- 螺旋輸料机叶片拉伸成型工艺.doc
- 螺旋輸送机传动装置设计.doc
- 螺旋輸送机一级斜齿圆柱齿轮减速器设计.docx
- 螺旋輪式管道机器人设计及其制作.doc
- 螺旋鉆孔灌注桩工程施工工艺及质量控制流程图.doc
- 螺旋鉆孔灌注桩施工.doc
- DB53_T 1000-2020 云南省公路工程高性能混凝土应用技术规程.docx
- 12J12 河北省12系列建筑标准设计图集 无障碍设施.docx
- DB54_T 0377-2024 畜牧业旱灾和雪灾天气指数保险.docx
- DB62_T 5034-2024 非金属类矿山土地复垦与生态修复技术规范.docx
- DB1504_T 2001-2022 基础地理空间数据库建设规范.docx
- DB62∕T 25-3108-2016 低丘缓坡未利用地开发技术规程.docx
- DB62_T 3222-2022 建设工程造价成果文件编制标准.docx
- DB53_T 1090-2022 高速公路交通气象站网建设技术规范.docx
- T_YCZCAQGCS 001-2024 注册安全工程师执业规范.docx
- 12J10 河北《附属建筑》.docx
最近下载
- CHZ系列智能型电动执行器操作手册-江苏兰阀通用设备有限公司.doc VIP
- 金融专业硕士学位论文写作.ppt VIP
- 高中数学学习中的数学与人工智能的结合.pptx VIP
- 国家外汇管理局黑龙江省分局资本项目外汇业务(FDI)知识竞赛试卷附答案.doc VIP
- 2025秋统编版(2024)道德与法治二年级上册第二单元 我爱我们班《第8课 我为班级做贡献》教学设计 .pdf
- 不发布招标计划的申请书.docx VIP
- 2021年6月浙江新高考英语卷试题及答案详解(精校打印版).pdf VIP
- 公安专业基础知识最全复习考点(打印版).doc VIP
- 2021年6 月普通高等学校招生全国统一考试(浙江卷英语).docx VIP
- 九三学社申请入社简历表.doc VIP
文档评论(0)