突发性泄漏事故中,经常发生污染源在短时间内突然释放大量的有害气体,此时对地面污染浓度的求解适合采用高斯烟团模型。烟团模型假定污染气云的体积沿水平和垂直方向增长,模拟污染气云在时间和空间上的变化。
高斯烟羽模式是计算释入大气中的气载污染物下风向浓度的应用最广的方法。此模式假定烟羽中污染物浓度分布在水平方向和垂直方向都遵循高斯分布。对于在恒定气象条件(指风向、风速、大气稳定度不随时间而变)高架点源的连续排放,在考虑了烟羽在地面的全反射后,下风向任一点的污染物浓度C (r,y,z)可由高斯烟羽公式进行模拟。
高斯扩散公式的建立有如下假设:
①风的平均流场稳定,风速均匀,风向平直;
②y、z轴方向符合正态分布;
③污染物在输送扩散中质量守恒;
④污染源的源强均匀、连续

如图所示,有效源位于坐标原点o处,平均风向与x轴平行,并与x轴正向同向。假设点源在没有任何障碍物的自由空间扩散,不考虑下垫面的存在。大气中的扩散是具有y与z两个坐标方向的二维正态分布,当两坐标方向的随机变量独立时,分布密度为每个坐标方向的一维正态分布密度函数的乘积。
经过推理得出计算公式:

C—空间点(x,y,z)的污染物的浓度,mg/m3;
σy、σz—分别为水平、垂直方向的标准差,即y、x方向的扩散参数
u —为平均风速
x —为风向轴上空间点到源的距离
y —为风向轴垂直方向上空间点到源的距离
z —为空间点的高度
σy、σz与大气稳定度和水平距离x有关,并随x的增大而增加。通过理论或经验的方法可得σ=f(x),可求出最大浓度点离源的距离x,具体可查阅我国GB384091《制定地方大气污染物排放标准的技术方法》。

式中c为污染物浓度(单位:mg/m3)
Q为源强(单位:mg/s)
u为泄漏高度的平均风速(单位:m/s)
y、z分别用浓度标准偏差表示的y轴及z轴上的扩散参数
H为泄漏有效高度(单位:m)
(1)污染物浓度在y、z轴上的分布符合高斯分布(正态分布);
(2)在全部空间中风速是均匀的、稳定的;
(3)源强是连续均匀的;
(4)在扩散过程中污染物质量是守恒的(不考虑转化)。
高斯模式的坐标系如下图所示,其原点为排放点(无界点源或地面源)或高架源排放点在地面的投影点,x轴正向为平均风向,y轴在水平面上垂直于x轴,正向在x轴的左侧,z轴垂直于水平面xoy,向上为正向,即为右手坐标系。

有效源高H,等于烟囱的几何高度与烟气抬升高度△H之和,即
对于一确定的烟囱,其几何高度H是确定值,只要计算出抬升高度△H值,就可以求出有效源高H。我国“制订地方大气污染物排放标准的技术方法”(GB/T13201-91)中规定选用Briggs 公式作为适用计算模型,请参考相关文献。
大气稳定度指大气中某一高度上的气团在垂直方向上的相对稳定程度。如果给一团空气一个初始作用力,使其作向上的垂直运动,垂直运动的气块在外力消失后,又逐渐回到原来的位置,这种状况的大气是稳定的;当外力消失后,气块仍继续上升,甚至加速前进,这种状况的大气是不稳定的;当外力消失后,气块停留在其已到达的位置,既不上升也不下降,这种状况的大气处于中性状态。
我国《环境影响评价技术导则》中推荐了用常规地面观测资料划分大气稳定度的方法。大气稳定度的分类方法采用经过修正的帕斯奎尔(Pasquill)稳定度分级法(Ps),将大气扩散稳定度分为强不稳定、不稳定、弱不稳定、中性、弱稳定和稳定六级,分别用A、B、C、D、E、F来表示。确定等级时首先根据云量与太阳高度角按下表查出太阳辐射等级数,再由太阳辐射等级数与地面风速按下表查找稳定度等级。



1. 有风时扩散参数、
:
扩散参数是大气稳定度和距离的函数,其表达式可写为以下幂指数的

如无实测值时,上述各指数、系数的值可按下述方法选取:
(1) 平原地区农村及城市远郊区的扩散参数如下:A、B、C级稳定度直接由表2-9和表2-10查算,D、E、F级稳定度则需向不稳定方向提半级后由表2-9和表2-10查算。
(2) 工业区或城区中的点源,其扩散参数选取方法如下:
A、B级不提级,C级提到B级,D、E、F级向不稳定方向提一级,再按表2-9和表2-10查算。


/**
* 获取横向扩散参数回归系数
*
* @param windSpeed 风速
* @param Q 大气稳定度
* @return
*/
public double getGamma01Light(double windSpeed, final String Q) {
double gamma = 0;
if (Q.equalsIgnoreCase("A")) {
if (windSpeed < 0.5) {
gamma = 0.93;
} else if (windSpeed < 1.5) {
gamma = 0.76;
}
} else if (Q.equalsIgnoreCase("B")) {
if (windSpeed < 0.5) {
gamma = 0.76;
} else if (windSpeed < 1.5) {
gamma = 0.56;
}
} else if (Q.equals("C")) {
if (windSpeed < 0.5) {
gamma = 0.55;
} else if (windSpeed < 1.5) {
gamma = 0.35;
}
} else if (Q.equals("D")) {
if (windSpeed < 0.5) {
gamma = 0.47;
} else if (windSpeed < 1.5) {
gamma = 0.27;
}
} else if (Q.equals("E")) {
if (windSpeed < 0.5) {
gamma = 0.44;
} else if (windSpeed < 1.5) {
gamma = 0.24;
}
} else if (Q.equals("F")) {
if (windSpeed < 0.5) {
gamma = 0.44;
} else if (windSpeed < 1.5) {
gamma = 0.24;
}
}
return gamma;
}
/**
* 获取铅直扩散参数回归系数
*
* @param windSpeed 风速
* @param Q 大气稳定度
* @return
*/
public double getGamma02Light(double windSpeed, final String Q) {
double gamma = 0;
if (Q.equalsIgnoreCase("A")) {
if (windSpeed < 0.5) {
gamma = 0.15;
} else if (windSpeed < 1.5) {
gamma = 1.57;
}
} else if (Q.equalsIgnoreCase("B")) {
if (windSpeed < 0.5) {
gamma = 0.47;
} else if (windSpeed < 1.5) {
gamma = 0.47;
}
} else if (Q.equals("C")) {
if (windSpeed < 0.5) {
gamma = 0.21;
} else if (windSpeed < 1.5) {
gamma = 0.21;
}
} else if (Q.equals("D")) {
if (windSpeed < 0.5) {
gamma = 0.12;
} else if (windSpeed < 1.5) {
gamma = 0.12;
}
} else if (Q.equals("E")) {
if (windSpeed < 0.5) {
gamma = 0.07;
} else if (windSpeed < 1.5) {
gamma = 0.07;
}
} else if (Q.equals("F")) {
if (windSpeed < 0.5) {
gamma = 0.05;
} else if (windSpeed < 1.5) {
gamma = 0.05;
}
}
return gamma;
}
package com.planet.engine.air.param;
import lombok.Data;
/**
* 运算参数
*/
@Data
public class AirProcParam {
/**
* 经纬度坐标系:污染点原点x
*/
private double lon = 108.14D;
/**
* 经纬度坐标系:污染点原点y
*/
private double lat = 36.27D;
/**
* 起算点即原点高程
*/
private Integer startEle = 0;
/**
* 投影横坐标
*/
private double x = 0;
/**
* 投影纵坐标
*/
private double y = 0;
/**
* 当前计算点z坐标
* 不做地形改正时,为计算点离地面高
* 做地形改正时,为计算点的高程改正值
*/
private double z = 20;
/**
* 模拟时间
* 单位秒
*/
private int timeSec = 600;
/**
* 扇形开度,算法要求不超过45度
*/
private double sectorAngle = 90;
/**
* 扇形弧段加密点数
*/
private int pointsNumSector = 6;
/**
* 扇形弧段加密点数
*/
private int pointsNumCircle = 24;
/**
* 高斯烟团或者高斯烟羽
* 分别用0和1表示
*/
private Integer type = 0;
/**
* 网格点间距,单位:米
*/
private float sideLen = 200f;
/**
* 密度阈值,单位mg/m3
* 超过此值的需要做叠加分析
*/
private Integer densityThr = 3;
}
package com.planet.controller;
import com.planet.common.annotations.LimitRequest;
import com.planet.engine.air.param.GaussAirParam;
import com.planet.model.SecurityUser;
import com.planet.model.enums.SimuType;
import com.planet.model.enums.StatusType;
import com.planet.service.GaussAirService;
import com.planet.service.SimuHistService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
/**
* Created by 之乎者也
*
*/
@RestController
@RequestMapping("/api/air")
@Api(value = "AirSimuApi", description = "空气污染扩散模拟模型")
public class AirSimuApi extends MyBaseApi {
@Autowired
private GaussAirService gaussAirService;
@Autowired
private SimuHistService simuHistService;
@LimitRequest
@ResponseBody
@RequestMapping(value = "/gauss", method = RequestMethod.POST)
@ApiOperation(value = "高斯烟羽扩散模拟接口")
public Result gaussSimu(@RequestBody GaussAirParam params) {
// 验证参数有效性,例如风速
String result = this.gaussAirService.calc(params);
// 异步保存历史纪录
SecurityUser securityUser = this.getLoginUser();
String paramsStr = this.getReqParams(params);
if(params.getProcParams().getType().equals(1)){
this.simuHistService.save(securityUser, SimuType.GAUSS_PLUME, paramsStr, StatusType.SUCCESS.code(), result);
}else{
this.simuHistService.save(securityUser, SimuType.GAUSS_BALL, paramsStr, StatusType.SUCCESS.code(), result);
}
return this.getResult(ResultCode.SUCCESS, result);
}
}
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢
我有一些非常大的模型,我必须将它们迁移到最新版本的Rails。这些模型有相当多的验证(User有大约50个验证)。是否可以将所有这些验证移动到另一个文件中?说app/models/validations/user_validations.rb。如果可以,有人可以提供示例吗? 最佳答案 您可以为此使用关注点:#app/models/validations/user_validations.rbrequire'active_support/concern'moduleUserValidationsextendActiveSupport: