网站大量收购闲置独家精品文档,联系QQ:2885784924

水质模型软件:SWMM二次开发_(8).SWMM扩展模块开发.docx

水质模型软件:SWMM二次开发_(8).SWMM扩展模块开发.docx

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

PAGE1

PAGE1

SWMM扩展模块开发

在上一节中,我们介绍了SWMM的基本功能和使用方法,包括其在城市排水系统和水质模拟中的应用。本节将重点探讨如何通过二次开发来扩展SWMM的功能,使其能够更好地满足特定项目的需求。SWMM的扩展模块开发主要涉及以下几个方面:自定义水质参数、开发新的水文过程、集成外部数据源以及优化模型性能。我们将会通过具体的例子来详细说明这些内容。

1.自定义水质参数

SWMM默认提供了一些水质参数,如COD、BOD、SS等,但在实际应用中,往往需要模拟更多特定的水质参数。自定义水质参数允许用户根据项目的具体需求添加新的水质变量,并在模型中进行计算和处理。

1.1原理

SWMM的水质模块是基于质量守恒原理的,即流入系统的水质质量等于流出系统的水质质量和系统内部的质量变化之和。自定义水质参数的原理与默认参数相同,但需要在源代码中添加新的变量和计算逻辑。

1.2内容

定义新的水质参数:首先需要在SWMM的输入文件中定义新的水质参数。这通常通过修改pollutants部分来实现。

修改源代码:在SWMM的源代码中,需要添加新的水质变量的定义,并在相应的计算函数中实现新的逻辑。

编译和测试:修改源代码后,需要重新编译SWMM,并进行测试以确保新的水质参数能够正确地参与模拟计算。

1.3例子

假设我们需要添加一个新的水质参数:硝酸盐(NO3)。

1.3.1定义新的水质参数

在SWMM的输入文件中,添加新的水质参数NO3:

[OPTIONS]

...

StartDate01/01/2023

StartTime00:00:00

EndDate01/02/2023

EndTime23:59:59

...

[POLLUTANTS]

NameUnitsCoeffExpKcKfLimit

NO3mg/L0.50.30.010.0210.0

1.3.2修改源代码

在SWMM的源代码中,找到处理水质参数的部分,例如Swmm5.c文件中的InitPollutants函数,添加新的NO3参数:

//Swmm5.c

voidInitPollutants(void)

{

intj,k;

for(j=0;jNobjects[POLLUT];j++)

{

pollut[j].index=j;

pollut[j].units=GetUnits(j);

pollut[j].coeff=getDouble(Coeff,j);

pollut[j].exp=getDouble(Exp,j);

pollut[j].kc=getDouble(Kc,j);

pollut[j].kf=getDouble(Kf,j);

pollut[j].limit=getDouble(Limit,j);

//新增NO3参数

if(strcmp(pollut[j].name,NO3)==0)

{

pollut[j].type=NO3;

}

}

}

在处理水质计算的函数中,例如Routing.c文件中的RoutePollutants函数,添加NO3的计算逻辑:

//Routing.c

voidRoutePollutants(doubledt)

{

inti,j,k;

for(i=0;iNobjects[SUBCATCH];i++)

{

for(j=0;jNobjects[POLLUT];j++)

{

doubleconc=subcatch[i].pollut[j].conc;

doubleload=subcatch[i].pollut[j].load;

//计算默认参数

if(pollut[j].type!=NO3)

{

//默认

文档评论(0)

找工业软件教程找老陈 + 关注
实名认证
服务提供商

寻找教程;翻译教程;题库提供;教程发布;计算机技术答疑;行业分析报告提供;

1亿VIP精品文档

相关文档