大气污染控制论文污染控制论文.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
大气污染控制论文污染控制论文 大气污染总量控制遗传算法的实现与性能优化  [摘要]介绍基于遗传算法的大气污染总量控制方法中遗传算法软件的结构设计、功能模块实现与性能优化技术,并给出若干关键功能模块的完整实现代码。对该软件进行性能检验的结果表明,该软件能稳定地求得问题的全局最优解,具有很好的推广应用前景。   [关键词]大气污染 总量控制 遗传算法 程序设计 性能优化   大气污染总量控制(Atmospheric Pollutant Total Emission Control,APTEC)是我国目前正在积极推行的一种先进的大气污染防治策略[1,2],它以大气环境容量为依据,控制给定区域内大气污染物的允许排放总量,并且优化分配到各污染源,从而确保该区域能实现大气环境质量目标[1-3]。基于遗传算法的大气污染总量控制方法[4,5]是利用遗传算法(Genetic Algorithm,GA)的全局搜索寻优功能[6],从地面控制点浓度来反推源强分布,从而得到经过全局优化的区域大气污染总量控制方案的一种新的大气污染总量控制技术。本文介绍基于遗传算法的大气污染总量控制方法中遗传算法软件的结构设计、编程实现与性能优化技术,并对其获取全局最优解的稳定性进行必要的检验。   一、遗传算法用于大气污染总量控制的基本原理   在基于遗传算法的大气污染总量控制中,设总量控制区域中有M个污染源,在该区域中选定N个有代表性的控制点。我们约定,在总量控制区内确定的这N个控制点用来确定整个区域的总量控制是否达到了控制标准,即只要这N个点达到了控制标准,则整个控制区域也就达到了控制标准。于是,一旦风向、风速、稳定度等影响因子确定了,则控制点的浓度由污染源的源强确定。改变各源的排污负荷分配,就会得到一个对应的浓度场。为了充分利用大气环境容量,我们希望区域允许排放总量达到最大,则应该使各控制点的实际污染浓度严格趋于标准浓度值。因为若某控制点的实际污染浓度低于标准浓度值,则可以认为该点所能代表的空间里还存在着剩余的环境容量没有得到有效的利用;相反,若实际污染浓度超过标准浓度值,则无疑是不符合大气污染总量控制的要求的。这样,在风向、风速、稳定度等影响到大气污染物扩散的因子确定了的情况下,如果能够找到某一种源强布局,使各个控制点的污染浓度正好等于它们所执行的大气环境质量标准,则认为此源强布局即为当前气象条件下最佳的源强布局,亦即总量控制问题的最优可行解。用遗传算法求算这一最优可行解的步骤是:   1.确定控制区域,根据功能分区确定控制点并给出各控制点将要执行的大气环境质量标准。通常可根据实际情况将控制区域划分为若干行、若干列的正方形网格,控制点取在正方形网格的中心点上,对污染源则按照有效源高分为若干层。   2.选定扩散模式,用于计算控制点的污染浓度。控制点的计算浓度与执行标准之间的偏差将作为衡量遗传算法中染色体优劣的标准,即利用这种偏差来计算个体的适应度,偏差越小,适应度越大。   3.将各污染源的源强编码为字符串,作为遗传算法操作的对象。按照遗传算法的工作流程逐步进化,直到找到符合要求的染色体为止。实际操作中,通常可以将计算浓度和环境标准之间的总体差异达到某个事先约定的小量作为终止进化的条件。   二、遗传算法软件的结构设计   为了将遗传算法用于大气污染总量控制,需要设计遗传算法软件。一般说来,选用什么样的编程语言并不重要,在常用的各种编程平台上都可以达到这一目的。但从软件的通用性和简捷性考虑,我们选用了比较容易掌握且拥有庞大用户群的Microsoft Visual C#.NET语言,开发了一个通用的遗传算法应用软件系统。   该软件包括系统初始化模块、适应度计算模块、轮盘选择模块、遗传操作模块和其它辅助模块。图1为遗传算法软件的结构图,图中给出了整个软件的模块组成以及它们之间的逻辑关系。      三、遗传算法软件的实现   (一)系统初始化模块   系统初始化模块完成系统参数的初始化及初始群体的生成。   1.系统参数初始化。系统参数包括群体规模、进化代数、目标精度、染色体长度、复制概率、交换概率、变异概率等,在系统启动时从磁盘文件中读入,在进化过程中允许对它们进行动态调整,以达到提高进化效率的目的。   2.初始群体的生成。初始群体的生成主要依靠一个随机数生成函数GetRndInt:   int GetRndInt(int lowerbound,int upperbound){   Random ra=new Random();return (int)((upperbound-lowerbound+1)*ra.NextDouble()+lowerbound);}   该函数获得某一区间内的随机整数,其中lowerbo

文档评论(0)

小教资源库 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档