




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Add a Physics Scheme into WRF Model,Shu-hua Chen UC Davis/AFWA,Physics implementation features Adding a physics scheme,Domain size: ids, ide, jds, jde, kds, kde Memory size: ims, ime, jms, jme, kms, kme Tile size: its, ite, jts, jte, kts, kte,Three Sets of Dimensions,Rules for WRF Physics,Naming rul
2、es,xxx = individual scheme ex, module_cu_kf.F,Naming Rules,module_yy_xxx.F (module),yy = ra is for radiation bl is for PBL cu is for cumulus mp is for microphysics.,YY = ra is for radiation bl is for PBL cu is for cumulus,Naming Rules,RXXYYTEN (tendencies),XX = variable (th, u, v, qv, qc, ),ex, RTHB
3、LTEN,Coding rules (later),Rules for WRF Physics,Naming rules,One scheme one module,WRF Physics Features, Unified global constatnts (module_model_constants.F), Unified global constatnts (module_model_constants.F), Vertical index (kms is at the bottom), Unified common calculations (saturation mixing r
4、atio),WRF Physics Features,WRF Language, 4D Moisture field, moist(i,k,j,?),? = P_QV (water vapor) P_QC (cloud water) P_QI (cloud ice) P_QR (rain) P_QS (snow) P_QG (graupel) (module_state_description.F),WRF Language, 4D Moisture field, moist(i,k,j,?), PARAM_FIRST_SCALAR,IF ( P_QI .ge. PARAM_FIRST_SCA
5、LAR ) (the memory of cloud ice is allocated) . . .,Prepare your code,Create a new module,Declare new variables and a new package in Registry,Modify solve_em.F (solve_eh.F),Implement a new physics scheme,Do initialization,Modify namelist,Modify phy_prep (module_em.F),Modify physics_,Modify c
6、umulus_driver.F,Modify Makefile,Compile and test,Modify calculate_phy_ten (module_em.F),Implement a new physics scheme,Modify phy_cu_ten (module_physics_addtendc.F),Replace continuation characters in the 6th column with f90 continuation & at end of previous line,1.F90,Prepare your code,Replace conti
7、nuation characters in the 6th column with f90 continuation & at end of previous line,1.F90,b)Replace the 1st column C for comment with !,Prepare your code,1.F90,2.No common block,Prepare your code,1.F90,2.No common block,3.Use “ implicit none ”,4.Use “ intent ”,Prepare your code,Subroutine sub(T,q,p
8、, .) real,intent(out), & dimension(ims:ime,kms:kme,jms:jme): T real,intent( in), & dimension(ims:ime,kms:kme,jms:jme): q real,intent(inout), & dimension(ims:ime,kms:kme,jms:jme): p,1.F90,2.No common block,3.Use “ implicit none ”,4.Use “ intent ”,5.Variable dimensions,Prepare your code,Subroutine sub
9、(glo,.) real,intent(out), & dimension(ims:ime,kms:kme,jms:jme): glo real,dimension(its:ite,kts:kte,jts:jte): loc,1.F90,2.No common block,3.Use “ implicit none ”,4.Use “ intent ”,5.Variable dimensions,6.Do loops,Prepare your code,Implement a new physics scheme,Create a new module,ex, module_cu_chen.F
10、 (put all your codes in),Go Registry and declare a new package (and new variables) (WRFV1/Registry),package chenscheme cu_physics=3 - -,package kfscheme cu_physics=1 - - package bmjscheme cu_physics=2 - -,Implement a new physics scheme,Cloud microphysics package kesslerscheme mp_physics=1 - moist:qv
11、,qc,qr package linscheme mp_physics=2 - moist:qv,qc,qr,qi,qs,qg package ncepcloud3 mp_physics=3 - moist:qv,qc,qr package ncepcloud5 mp_physics=4 - moist:qv,qc,Create a new module,ex, module_cu_chen.F (put all your codes in),Go Registry and declare a new package (and new variables) (WRFV1/Registry),I
12、mplement a new physics scheme,Modify namelist.input and assign,cu_physics = 3,Create a new module,ex, module_cu_chen.F (put all your codes in),Go Registry and declare a new package (and new variables) (WRFV1/Registry),INIT,WRF,.,solve_em,phy_init,start_domain_em,cu_init,(dyn_em) (start_em.F),(phys)
13、(module_physics_init.F),(dyn_em),phys/module_physics_init.F,Pass new variables down to cu_init,INIT,WRF,.,solve_em,phy_init,start_domain_em,cu_init,(dyn_em) (start_em.F),(phys) (module_physics_init.F),(dyn_em),phys/module_physics_init.F,Go subroutine cu_init Include the new module and create a new S
14、ELECT case,Pass new variables down to cu_init,cps_select: SELECT CASE(config_flags%cu_physics) CASE (KFSCHEME) CALL kfinit(.) CASE (BMJSCHEME) CALL bmjinit(.) CASE DEFAULT END SELECT cps_select,Subroutine cu_init() . USE module_cu_kf USE module_cu_bmj .,CASE (CHENSCHEME) CALL cheninit(.),phys/module
15、_physics_init.F,USE module_cu_chen,WRF,solve_em,DYNAMICS,phy_init,INIT,.,.,phy_prep,moist_physics_prep,phy_prep/moist_physics_prep, Calculate required variables, Convert variables from C grid to A grid,WRF,solve_em,DYNAMICS,phy_init,INIT,.,.,microphysics_driver,radiation_driver,cumulus_driver,pbl_dr
16、iver,phy_prep,moist_physics_prep,chencps,Three-level structure,solve_em,Go physics driver (cumulus_driver.F) Include the new module and create a new SELECT CASE in driver Check available variables in drivers (variables are explained inside drivers),cumulus_driver.F,Subroutine cumulus_driver . USE mo
17、dule_cu_kf USE module_bmj_kf .,cumulus_driver.F,USE module_cu_chen,cps_select: SELECT CASE(config_flags%cu_physics) CASE (KFSCHEME) CALL KFCPS(.) CASE (BMJSCHEME) CALL BMJCPS(.) CASE DEFAULT END SELECT cps_select,CASE (CHENSCHEME) CALL CHENCPS(.),SUBROUTINE cumulus_driver(arg1, arg2, & newvar1, newv
18、ar2, & its,ite,jts,jte,kts,kte, & ims,ime,jms,jme,kms,kme, & ids,ide,jds,jde,kds,kde ) INTEGER, INTENT(IN) : its,ite,jts,jte,kts,kte, & ims,ime,jms,jme,kms,kme, & ids,ide,jds,jde,kds,kde REAL, INTENT(IN) : arg1, arg2 REAL, INTENT(OUT), DIMENSION(kms:kme) : & newvar1,newvar2,.,Physics_,solve_em,cumulus_driver,c
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 山东省济南市长清第一中学大学科技园校区2025年物理高二第二学期期末学业水平测试试题含解析
- 上海市宝山区高境一中2025届物理高二下期末检测试题含解析
- 日喀则市2025届物理高二下期末复习检测模拟试题含解析
- 2025年湖南省祁东县第一中学物理高二第二学期期末考试模拟试题含解析
- 2025届浙江省名校协作体联盟物理高一下期末经典试题含解析
- 二零二五年环保设备买卖与环保项目合作合同
- 二零二五年度场监管总局全国合同示范文本库-政府采购合同示范文本
- 二零二五年度污水处理厂epc总承包合同
- 二零二五版参股合作投资合同范本解读
- 二零二五年度报关销售合同范本针对高新技术产品
- 2024年安徽电气工程职业技术学院高职单招职业技能测验历年参考题库(频考版)含答案解析
- 人教版(2025新版)七年级下册数学第七章 相交线与平行线 单元测试卷(含答案)
- 《铁路技术管理规程》(普速铁路部分)
- 储能电站基础知识
- 夫妻婚内财产约定协议书范本(2025年)
- 信息技术设备互连 智能家居互联互通 第1部分:架构与要求 征求意见稿
- 2024年数智工程师职业鉴定考试复习题库(含答案)
- 北师大版数学六年级上学期期中试卷
- 中风脑梗死恢复期中医护理方案课件
- 《细菌毒素》课件
- 校长教职工大会讲话材料
评论
0/150
提交评论