WRF进阶:antro_emiss工具处理全球大气人为排放(EDGRA_HTTPs)/人为排放清单前处理

news2025/1/10 18:47:36

本内容视频版讲解:全球人为排放处理

介绍

一般人为数据的排放前处理使用pre_chen_src工具,然而pre_chen_src处理后的文件并不是WRF所能读取的文件格式,需要使用onvert_emiss.exe,生成WRF需要的人为排放的nc数据。
在WRF-chem3.6以后,onvert_emiss.exe便不再WRF的编译中,需要单独安装,显然较为麻烦,而WRF本身就提供了处理全球人为排放数据的工具antro_emiss tool可用于对IPCC/EDAGR的人为排放源的预处理,

下载

在DOWNLOAD WRF-CHEM PROCESSORS中,先填入相应的信息,随后点击下载antro_emiss工具,
在这里插入图片描述

安装

将下载的安装包解压,检查依赖包与环境变量配置。
该工具依赖于fortran90编译,同时依赖于netcef包。
根据你的Fortran编译器(pg90、infetl,ifort等等),设置环境变量,比如我的编译器为ifort,我就需要:

export FC=ifort 

另外,该工具通过NETCDF_DIR来查找你的NETCEF,因此你需要添加NETCDF_DIR= your netcdf path。
之后,运行命令:

./make_anthro

即可。

使用

antro_emiss的使用与安装方法,全都在解压的README.anthro_emis文件中,该文件给出了该工具的使用方法与适用条件,使用者应当仔细阅读。
使用antro_emiss需要下载对应的输入数据,再根据数据设置对应的namelist文件,该文件后缀名为inp,随后,

./anthro_emis < anthro_emis.inp

运行即可。

namelis.input文件

inp文件用于告知antro_emiss所需的信息。
对于antro_emiss而言,它需要知道以下信息:

  1. 输入数据的路径:根据该路径,查找用于输入的清单数据。
  2. WRF路径:根据该路径,寻找wrf_input文件,根据input文件,获取WRF的投影、模拟域等信息。
  3. 文件名:清单数据的文件命名。通过该部分,可以批量读取类似命名格式的清单数据。
  4. 时间:模拟开始于结束时间、间隔等等。
  5. 映射(Mapping):WRF变量和排放源变量的映射关系,即排放清单的变量名对WRF的一种解释。

相关的详细说明可以去查看README文件。

实例

如果只查看README,会对它的说明感到困惑,尤其是Mapping部分,虽然READEME中提供了几个inp文件的例子,但缺少具体的数据与更加详细的说明,仍然让人难以一时理解。
在这里我用一个实例来向大家说明。
使用的数据是EDGAR2018年的BC排放数据,下载地址:htap_v3-BC

我们首先查看一下下载的排放数据的信息:

netcdf edgar_HTAPv3_2018_BC {
dimensions:
        lat = 1800 ;
        lon = 3600 ;
        time = 12 ;
variables:
        double lat(lat) ;
                lat:units = "degrees_north" ;
                lat:standard_name = "latitude" ;
                lat:long_name = "latitude" ;
        double lon(lon) ;
                lon:units = "degrees_east" ;
                lon:standard_name = "longitude" ;
                lon:long_name = "longitude" ;
        float time(time) ;
                time:long_name = "time" ;
                time:standard_name = "time" ;
                time:units = "days since 2018-01-01 00:00:00" ;
        float HTAPv3_1_International_Shipping(time, lat, lon) ;
                HTAPv3_1_International_Shipping:_FillValue = 9.96921e+36f ;
                HTAPv3_1_International_Shipping:units = "ton/month" ;
                HTAPv3_1_International_Shipping:long_name = "International Shipping" ;
                HTAPv3_1_International_Shipping:description = "International_Shipping" ;
        float HTAPv3_2_1_Domestic_Aviation(time, lat, lon) ;
                HTAPv3_2_1_Domestic_Aviation:_FillValue = 9.96921e+36f ;
                HTAPv3_2_1_Domestic_Aviation:units = "ton/month" ;
                HTAPv3_2_1_Domestic_Aviation:long_name = "Domestic Aviation" ;
                HTAPv3_2_1_Domestic_Aviation:description = "Domestic_Aviation" ;
        float HTAPv3_2_2_International_Aviation(time, lat, lon) ;
                HTAPv3_2_2_International_Aviation:_FillValue = 9.96921e+36f ;
                HTAPv3_2_2_International_Aviation:units = "ton/month" ;
                HTAPv3_2_2_International_Aviation:long_name = "International Aviation" ;
                HTAPv3_2_2_International_Aviation:description = "International_Aviation" ;
        float HTAPv3_3_Energy(time, lat, lon) ;
                HTAPv3_3_Energy:_FillValue = 9.96921e+36f ;
                HTAPv3_3_Energy:units = "ton/month" ;
                HTAPv3_3_Energy:long_name = "Energy" ;
                HTAPv3_3_Energy:description = "Energy" ;
        float HTAPv3_4_1_Industry(time, lat, lon) ;
                HTAPv3_4_1_Industry:_FillValue = 9.96921e+36f ;
                HTAPv3_4_1_Industry:units = "ton/month" ;
                HTAPv3_4_1_Industry:long_name = "Industry" ;
                HTAPv3_4_1_Industry:description = "Industry" ;
        float HTAPv3_4_2_Fugitive(time, lat, lon) ;
                HTAPv3_4_2_Fugitive:_FillValue = 9.96921e+36f ;
                HTAPv3_4_2_Fugitive:units = "ton/month" ;
                HTAPv3_4_2_Fugitive:long_name = "Fugitive" ;
                HTAPv3_4_2_Fugitive:description = "Fugitive" ;
        float HTAPv3_4_3_Solvents(time, lat, lon) ;
                HTAPv3_4_3_Solvents:_FillValue = 9.96921e+36f ;
                HTAPv3_4_3_Solvents:units = "ton/month" ;
                HTAPv3_4_3_Solvents:long_name = "Solvents" ;
                HTAPv3_4_3_Solvents:description = "Solvents" ;
        float HTAPv3_5_1_Road_Transport(time, lat, lon) ;
                HTAPv3_5_1_Road_Transport:_FillValue = 9.96921e+36f ;
                HTAPv3_5_1_Road_Transport:units = "ton/month" ;
                HTAPv3_5_1_Road_Transport:long_name = "Road Transport" ;
                HTAPv3_5_1_Road_Transport:description = "Road_Transport" ;
        float HTAPv3_5_2_Brake_and_Tyre_wear(time, lat, lon) ;
                HTAPv3_5_2_Brake_and_Tyre_wear:_FillValue = 9.96921e+36f ;
                HTAPv3_5_2_Brake_and_Tyre_wear:units = "ton/month" ;
                HTAPv3_5_2_Brake_and_Tyre_wear:long_name = "Brake and Tyre wear" ;
                HTAPv3_5_2_Brake_and_Tyre_wear:description = "Brake_and_Tyre_wear" ;
        float HTAPv3_5_3_Domestic_shipping(time, lat, lon) ;
                HTAPv3_5_3_Domestic_shipping:_FillValue = 9.96921e+36f ;
                HTAPv3_5_3_Domestic_shipping:units = "ton/month" ;
                HTAPv3_5_3_Domestic_shipping:long_name = "Domestic shipping" ;
                HTAPv3_5_3_Domestic_shipping:description = "Domestic_shipping" ;
        float HTAPv3_5_4_Other_ground_transport(time, lat, lon) ;
                HTAPv3_5_4_Other_ground_transport:_FillValue = 9.96921e+36f ;
                HTAPv3_5_4_Other_ground_transport:units = "ton/month" ;
                HTAPv3_5_4_Other_ground_transport:long_name = "Other ground transport" ;
                HTAPv3_5_4_Other_ground_transport:description = "Other_ground_transport" ;
        float HTAPv3_6_Residential(time, lat, lon) ;
                HTAPv3_6_Residential:_FillValue = 9.96921e+36f ;
                HTAPv3_6_Residential:units = "ton/month" ;
                HTAPv3_6_Residential:long_name = "Residential" ;
                HTAPv3_6_Residential:description = "Residential" ;
        float HTAPv3_7_Waste(time, lat, lon) ;
                HTAPv3_7_Waste:_FillValue = 9.96921e+36f ;
                HTAPv3_7_Waste:units = "ton/month" ;
                HTAPv3_7_Waste:long_name = "Waste" ;
                HTAPv3_7_Waste:description = "Waste" ;
        float HTAPv3_8_1_Agricultural_waste_burning(time, lat, lon) ;
                HTAPv3_8_1_Agricultural_waste_burning:_FillValue = 9.96921e+36f ;
                HTAPv3_8_1_Agricultural_waste_burning:units = "ton/month" ;
                HTAPv3_8_1_Agricultural_waste_burning:long_name = "Agricultural waste burning" ;
                HTAPv3_8_1_Agricultural_waste_burning:description = "Agricultural_waste_burning" ;
        float HTAPv3_8_2_Agriculture_livestock(time, lat, lon) ;
                HTAPv3_8_2_Agriculture_livestock:_FillValue = 9.96921e+36f ;
                HTAPv3_8_2_Agriculture_livestock:units = "ton/month" ;
                HTAPv3_8_2_Agriculture_livestock:long_name = "Agriculture livestock" ;
                HTAPv3_8_2_Agriculture_livestock:description = "Agriculture_livestock" ;
        float HTAPv3_8_3_Agriculture_crops(time, lat, lon) ;
                HTAPv3_8_3_Agriculture_crops:_FillValue = 9.96921e+36f ;
                HTAPv3_8_3_Agriculture_crops:units = "ton/month" ;
                HTAPv3_8_3_Agriculture_crops:long_name = "Agriculture crops" ;
                HTAPv3_8_3_Agriculture_crops:description = "Agriculture_crops" ;


可以看到,有许多变量,表明不同的BC排放来源,而在antro_emiss中,我们正是通过Mapping这一部分,对数据的变量进行说明,即mapping告诉该工具,对于排放清单的变量,读取哪一些,读取的那些变量分别代表什么,在处理后,WRF应当怎么读取它们。
比如这里,我只想读取Energy和Industry的排放的BC,我在mapping部分的categories和cat_var部分这样设置:

&CONTROL
 wrf_dir='/public/home/zhangzilu/Build_WRF/WRF-4.3/run'
 anthro_dir ='/public/home/zhangzilu/Build_WRF/ANTHRO/src'
 src_file_prefix = 'edgar_HTAPv3_2018_'
 src_file_suffix = '.nc'
 src_names = 'BC(12)'# (12)规定了分子量,必须规定
 sub_categories= '3_Energy' '4_1_Industry'
 cat_var_suffix = ''
 cat_var_prefix = 'HTAPv3_'
 emis_map  = 'BC(a) -> BC' #(a)表明为气溶胶粒子
 serial_output = .true.
 start_output_time  = '2018-03-02_12:00:00'
 stop_output_time   = '2018-03-07_12:00:00'
 output_interval = 43200
/

这是,antro_emiss,便读取了/public/home/zhangzilu/Build_WRF/ANTHRO/src/edgar_HTAPv3_2018_BC.nc文件里的TAPv3_3_Energy和 float HTAPv3_4_1_Industry变量,输出到了wrfchemi文件中。
在这里插入图片描述
wrfchemi变量如下:

netcdf wrfchemi_d01_2018-03-05_00\:00\:00 {
dimensions:
        west_east = 219 ;
        south_north = 219 ;
        emissions_zdim_stag = 10 ;
        DateStrLen = 19 ;
        Time = UNLIMITED ; // (1 currently)
variables:
        char Times(Time, DateStrLen) ;
        float XLONG(south_north, west_east) ;
                XLONG:MemoryOrder = "XY " ;
                XLONG:description = "LONGITUDE, WEST IS NEGATIVE" ;
                XLONG:units = "degree east" ;
                XLONG:stagger = "" ;
                XLONG:FieldType = 104 ;
        float XLAT(south_north, west_east) ;
                XLAT:MemoryOrder = "XY " ;
                XLAT:description = "LATITUDE, SOUTH IS NEGATIVE" ;
                XLAT:units = "degree north" ;
                XLAT:stagger = "" ;
                XLAT:FieldType = 104 ;
        float E_BC(Time, emissions_zdim_stag, south_north, west_east) ;
                E_BC:MemoryOrder = "XYZ" ;
                E_BC:description = "EMISSIONS" ;
                E_BC:units = "ug m^-2 s^-1" ;
                E_BC:stagger = "Z" ;
                E_BC:FieldType = 104 ;


随后在WRF的namelist中设置对应auxinput将生成的排放读取即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/114455.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

煤矿视频监控分析检测 yolo

煤矿视频监控分析检测利用python基于yolo深度学习架构&#xff0c;对现场画面进行实时分析检测。我们使用YOLO(你只看一次)算法进行对象检测。YOLO是一个聪明的卷积神经网络(CNN)&#xff0c;用于实时进行目标检测。该算法将单个神经网络应用于完整的图像&#xff0c;然后将图像…

单片机——LED点阵

1. 基本介绍 LED点阵 LED点阵是由发光二极管排列组成的显示器件&#xff0c;通常应用较多的是88点阵&#xff0c;然后通过多个88点阵组成不同分辨率的LED点阵显示屏&#xff0c;如4个88组成的1616点阵 8*8点阵由64个LED组成&#xff0c;每个LED是放置在行线和列线的交叉点上…

LVGL学习笔记3 - 样式Style

目录 1. 初始化样式 2. 设置样式 3. 添加和移除样式 4. 验证 5. 状态&#xff08;State&#xff09; 6. 部分&#xff08;Parts&#xff09; 样式用于设置对象的外观&#xff0c;比如颜色等属性&#xff0c;存储在 lv_style_t 变量中&#xff0c;这个变量应该是static…

不写一行代码(二):实现安卓基于PWM的LED设备驱动

文章目录一、前言二、系列文章三、准备工作3.1 查找PWM引脚3.2 原理图&#xff1a;确认引脚位置3.3 PWM Controller四、查阅PWM bindings五、编写设备树节点5.1 实现节点&#xff1a;pwm-leds5.2 测试命令六、后语一、前言 在完成了基于GPIO的LED设备驱动的文章后&#xff0c;…

3天学会撰写软件发明专利——3.生命周期

“无意中发现了一个巨牛的人工智能教程&#xff0c;忍不住分享一下给大家。教程不仅是零基础&#xff0c;通俗易懂&#xff0c;而且非常风趣幽默&#xff0c;像看小说一样&#xff01;觉得太牛了&#xff0c;所以分享给大家。点这里可以跳转到教程。”。 一、专利授权生命周期…

4.1 协程:协程基础

1.协程 协程&#xff0c;又称微线程。协程是python个中另外一种实现多任务的方式&#xff0c;只不过比线程更小占用更小执行单元&#xff08;理解为需要的资源&#xff09;。 为啥说它是一个执行单元&#xff0c;因为它自带CPU上下文。这样只要在合适的时机&#xff0c; 我们可…

C++类和对象概念及实现详解(上篇)

文章目录 一、什么是类和对象呢&#xff1f; 1、类的引入 2、类的定义 3、类的访问限定符 4、类对象的储存方式 5、this指针的特性 二、类的六个默认成员函数详解 1、构造函数 2、析构函数 3、未完待续…… 标题&#xff1a;类和对象概念及实现详解&#xff08;上篇&#xff0…

vue3 antd table表格——自定义单元格样式(二)利用rowClassName给table添加行样式

vue3 antd项目实战——修改ant design vue组件中table表格的默认样式&#xff08;二&#xff09;知识调用场景复现修改table表格的行样式一、rowClassName添加行样式二、表格的不可控操作写在最后知识调用 文章中可能会用到的知识链接vue3ant design vuets实战【ant-design-vu…

从头开始用树莓派做一个NAS【最新超详细教程】

一、概述 众所周知在办公的时候两台电脑之间经常倒数据资料非常麻烦&#xff0c;而NAS可以很好的解决这个问题。树莓派搭建NAS方法有很多&#xff0c;我们之前也拍过直接用Samba、FTP这些来实现NAS功能&#xff0c;但是这些需要你会在命令行进行配置&#xff0c;而且对于新手用…

【Linux】Linux权限管理

目录一.Linux用户权限1.权限的概念2.用户分类3.切换用户4.sudo提权二.Linux文件权限1.文件属性2.文件类型3.文件角色划分4.基本权限三.文件访问权限的相关设置方法1.chmod2.chown3.charp4.file5.权限拒绝四.默认权限umask五.目录的权限六.粘滞位1.背景2.准备3.情况4.粘滞位一.L…

初识Docker:(1)什么是docker

初识Docker&#xff1a;&#xff08;1&#xff09;什么是docker项目部署的问题Docker总结项目部署的问题 大型项目组件较多&#xff0c;运行环境也较为复杂&#xff0c;部署时会碰到一些问题&#xff1a; 依赖关系复杂&#xff0c;容易出现兼容性问题开发、测试、生产环境有差…

git revert以及revert的恢复

一&#xff1a;背景与方案 在工作中遇见的这样的场景&#xff1a; 场景一&#xff1a; 已经merge到待发布的版本分支中的功能需要移除当前的分支&#xff0c;改在后续版本发布&#xff0c;示意图如下&#xff0c;展示的是commit序列&#xff0c; 这里想要移除的功能是commi…

[python库] base64库的基本使用

1. base64是什么 base64是一种二进制到文本格式的编码方式。具体来说就是将byte数组编码为字符串的方法&#xff0c;而编码出来的字符串只包含ASCII基础字符。 虽然说base64是一种编码方式&#xff0c;但是它并不推荐作为常规的加密算法使用&#xff0c;因为该算法的加解密算法…

Android开发进阶——binder通讯学习

什么是binder 通常意义下&#xff0c;binder指的是一种通信机制对Server端来说&#xff0c;Binder指的是Binder本地对象&#xff0c;对于Client端来说&#xff0c;Binder指的是Binder代理对象对于传输过程而言&#xff0c;binder是可以跨进程传输的对象 Binder的基本原理 Bi…

【工作流Activiti7】7、Activiti7+SpringBoot

1. 版本问题 1.1. Activiti版本 7.1.0-M6是最后一个支持JDK1.8的版本&#xff0c;此后的版本都要求JDK11以上 目前&#xff0c;Activiti最新版本是7.6.0&#xff0c;它是用JDK11编译的&#xff0c;因此要想使用最新版7.6.0必须升级JDK版本&#xff0c;不能再用1.8 同时&…

【数组中数字出现的次数-有限状态自动机】

数组中数字出现的次数一&#xff0c;有限状态自动机解法二&#xff0c;一般解法想必大家对数组中数字出现的次数的这种题并不少见&#xff0c; 主要有三种&#xff1a; 1&#xff0c;找出数组中只出现一次的数字&#xff08;其他数字出现两次&#xff09; 2&#xff0c;找出数组…

渗透测试指操作系统漏洞发现与防御概述

今天继续给大家介绍渗透测试相关知识&#xff0c;本文主要内容是渗透测试指操作系统漏洞发现与防御概述。 免责声明&#xff1a; 本文所介绍的内容仅做学习交流使用&#xff0c;严禁利用文中技术进行非法行为&#xff0c;否则造成一切严重后果自负&#xff01; 再次强调&#x…

Android四大组件之Service

文章目录Android四大组件之默默劳动的Service什么是ServiceAndroid多线程编程线程的基本用法在子线程中更新UI解析异步消息处理机制MessageHandlerMessageQueueLooper异步消息的整个流程使用AsyncTaskService的基本用法定义一个Service启动和停止ServiceActivity和Service进行通…

【4】axi协议学习

1、axi背景介绍: Advanced extensible Interface(AXI)是为了满足高性能系统设计而定义的一套独立通道协议,首次是在2003年发布的AMBA3标准中出现,经历AMBA4,目前已经到达AMBA5版本。 2、axi 特性: AXI满足如下的特性: 适合于高带宽,低延迟的设计 不需要通过复杂的桥…

去耦电容和旁路的概念说明与应用说明

回想当初第一眼看觉得&#xff0c;这啥玩意自己又菜了&#xff01; 电容&#xff1a;本质就是充放电&#xff0c;实际应该我们围着这个来转 一、解释 旁路电容从英文角度看&#xff0c;就是抄小路的意思&#xff0c;意思当有一个干扰来临时候&#xff0c;可以通过这个电容抄…