r4627 | gill | 2010-12-29 16:29:58 -0700 (Wed, 29 Dec 2010) | 5 lines
[wrffire.git] / wrfv2_fire / dyn_em / module_first_rk_step_part1.F
blob65527fe74af876a5c647531766b81a70fbbab6b9
1 !WRF:MEDIATION_LAYER:SOLVER
3 #define BENCH_START(A)
4 #define BENCH_END(A)
6 MODULE module_first_rk_step_part1
8 CONTAINS
10   SUBROUTINE first_rk_step_part1 (   grid , config_flags              &
11                              , moist , moist_tend               &
12                              , chem  , chem_tend                &
13                              , tracer, tracer_tend              &
14                              , scalar , scalar_tend             &
15                              , fdda3d, fdda2d                   &
16                              , ru_tendf, rv_tendf               &
17                              , rw_tendf, t_tendf                &
18                              , ph_tendf, mu_tendf               &
19                              , tke_tend                         &
20                              , adapt_step_flag , curr_secs      &
21                              , psim , psih , wspd , gz1oz0 , br , chklowq &
22                              , cu_act_flag , hol , th_phy        &
23                              , pi_phy , p_phy , t_phy , u_phy , v_phy     &
24                              , dz8w , p8w , t8w , rho_phy , rho           &
25                              , ids, ide, jds, jde, kds, kde     &
26                              , ims, ime, jms, jme, kms, kme     &
27                              , ips, ipe, jps, jpe, kps, kpe     &
28                              , imsx,imex,jmsx,jmex,kmsx,kmex    &
29                              , ipsx,ipex,jpsx,jpex,kpsx,kpex    &
30                              , imsy,imey,jmsy,jmey,kmsy,kmey    &
31                              , ipsy,ipey,jpsy,jpey,kpsy,kpey    &
32                              , k_start , k_end                  &
33                              , f_flux                           &
34                             )
35     USE module_state_description
36     USE module_model_constants
37     USE module_domain, ONLY : domain, domain_clock_get, get_ijk_from_subgrid
38     USE module_configure, ONLY : grid_config_rec_type, model_config_rec
39     USE module_radiation_driver, ONLY : pre_radiation_driver, radiation_driver
40     USE module_surface_driver, ONLY : surface_driver
41     USE module_cumulus_driver, ONLY : cumulus_driver
42     USE module_pbl_driver, ONLY : pbl_driver
43     USE module_fr_sfire_driver, ONLY : sfire_driver_em_step
44     USE module_fddagd_driver, ONLY : fddagd_driver
45     USE module_em, ONLY : init_zero_tendency
46     USE module_force_scm
47     USE module_convtrans_prep
48     USE module_big_step_utilities_em, ONLY : phy_prep
49 use module_scalar_tables
50 #ifdef DM_PARALLEL
51     USE module_dm, ONLY : local_communicator, mytask, ntasks, ntasks_x, ntasks_y, local_communicator_periodic, wrf_dm_maxval
52     USE module_comm_dm, ONLY : halo_em_phys_a_sub,halo_em_fdda_sfc_sub
53 #endif
54     USE module_utility
55     IMPLICIT NONE
57     TYPE ( domain ), INTENT(INOUT) :: grid
58     TYPE ( grid_config_rec_type ), INTENT(IN) :: config_flags
59     TYPE(WRFU_Time)                :: currentTime
61     INTEGER, INTENT(IN) :: ids, ide, jds, jde, kds, kde,     &
62                            ims, ime, jms, jme, kms, kme,     &
63                            ips, ipe, jps, jpe, kps, kpe,     &
64                            imsx,imex,jmsx,jmex,kmsx,kmex,    &
65                            ipsx,ipex,jpsx,jpex,kpsx,kpex,    &
66                            imsy,imey,jmsy,jmey,kmsy,kmey,    &
67                            ipsy,ipey,jpsy,jpey,kpsy,kpey
70     LOGICAL ,INTENT(IN)                        :: adapt_step_flag
71     REAL, INTENT(IN)                           :: curr_secs
73     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_moist),INTENT(INOUT)   :: moist
74     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_moist),INTENT(INOUT)   :: moist_tend
75     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_chem),INTENT(INOUT)   :: chem
76     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_chem),INTENT(INOUT)   :: chem_tend
77     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_tracer),INTENT(INOUT)   :: tracer
78     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_tracer),INTENT(INOUT)   :: tracer_tend
79     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_scalar),INTENT(INOUT)   :: scalar
80     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_scalar),INTENT(INOUT)   :: scalar_tend
81     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme,num_fdda3d),INTENT(INOUT)  :: fdda3d
82     REAL    ,DIMENSION(ims:ime,1:1,jms:jme,num_fdda2d),INTENT(INOUT)      :: fdda2d
83     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: psim
84     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: psih
85     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: wspd
86     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: gz1oz0
87     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: br
88     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: chklowq
89     LOGICAL ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: cu_act_flag
90     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT)         :: hol
92     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: th_phy
93     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: pi_phy
94     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: p_phy
95     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: t_phy
96     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: u_phy
97     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: v_phy
98     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: dz8w
99     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: p8w
100     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: t8w
101     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: rho_phy
102     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: rho
104     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: ru_tendf
105     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: rv_tendf
106     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: rw_tendf
107     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: ph_tendf
108     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: t_tendf
109     REAL    ,DIMENSION(ims:ime,kms:kme,jms:jme), INTENT(INOUT) :: tke_tend
111     REAL    ,DIMENSION(ims:ime,jms:jme), INTENT(INOUT) :: mu_tendf
113     INTEGER, INTENT(IN)                           ::  k_start, k_end
114     LOGICAL, INTENT(IN), OPTIONAL                 ::  f_flux
116 ! Local
117     REAL, DIMENSION( ims:ime, jms:jme ) :: exch_temf  ! 1/7/09 WA
119     REAL, DIMENSION( ims:ime, jms:jme ) :: ht_loc, mixht
120     INTEGER                             :: ij
121     INTEGER  num_roof_layers
122     INTEGER  num_wall_layers
123     INTEGER  num_road_layers
124     INTEGER  iswater
125     LOGICAL  :: l_flux
126     INTEGER  :: isurban
127     INTEGER  rk_step
128     INTEGER                         :: yr, month, day, hr, minute, sec, rc
129     CHARACTER*80                    :: mesg
131    INTEGER                         :: sids , side , sjds , sjde , skds , skde , &
132                                       sims , sime , sjms , sjme , skms , skme , &
133                                       sips , sipe , sjps , sjpe , skps , skpe
135    CHARACTER (LEN=256) :: mminlu
137 #if ( WRF_DFI_RADAR == 1 )
138     INTEGER  do_capsupress   ! =1 do CAP supress, other = don't
139 #endif
141   CALL get_ijk_from_subgrid (  grid ,                   &
142                             sids, side, sjds, sjde, skds, skde,    &
143                             sims, sime, sjms, sjme, skms, skme,    &
144                             sips, sipe, sjps, sjpe, skps, skpe    )
146  ! initialize all tendencies to zero in order to update physics
147  ! tendencies first (separate from dry dynamics).
149    l_flux=.FALSE.
150    if (present(f_flux)) l_flux=f_flux
152     rk_step = 1
154 BENCH_START(init_zero_tend_tim)
155        !$OMP PARALLEL DO   &
156        !$OMP PRIVATE ( ij )
158        DO ij = 1 , grid%num_tiles
160          CALL wrf_debug ( 200 , ' call init_zero_tendency' )
161          CALL init_zero_tendency ( ru_tendf, rv_tendf, rw_tendf,     &
162                                    ph_tendf, t_tendf, tke_tend,      &
163                                    mu_tendf,                         &
164                                    moist_tend,chem_tend,scalar_tend, &
165                                    tracer_tend,num_tracer,           &
166                                    num_moist,num_chem,num_scalar,    &
167                                    rk_step,                          &
168                                    ids, ide, jds, jde, kds, kde,     &
169                                    ims, ime, jms, jme, kms, kme,     &
170                                    grid%i_start(ij), grid%i_end(ij), &
171                                    grid%j_start(ij), grid%j_end(ij), &
172                                    k_start, k_end                   )
174        END DO
175        !$OMP END PARALLEL DO
176 BENCH_END(init_zero_tend_tim)
178 #ifdef DM_PARALLEL
179 #     include "HALO_EM_PHYS_A.inc"
180 #endif
182       !$OMP PARALLEL DO   &
183       !$OMP PRIVATE ( ij )
184       DO ij = 1 , grid%num_tiles
186         CALL wrf_debug ( 200 , ' call phy_prep' )
187         CALL phy_prep ( config_flags,                           &
188                         grid%mut, grid%muu, grid%muv, grid%u_2, &
189                         grid%v_2, grid%p, grid%pb, grid%alt,              &
190                         grid%ph_2, grid%phb, grid%t_2, grid%tsk, moist, num_moist,   &
191                         rho,th_phy, p_phy, pi_phy, u_phy, v_phy,    &
192                         p8w, grid%t_phy, t8w, grid%z, grid%z_at_w, dz8w, &
193                         grid%p_hyd, grid%p_hyd_w,                   &
194                         grid%fnm, grid%fnp, grid%znw, grid%p_top,   &
195                         grid%rthraten,                          &
196                         grid%rthblten, grid%rublten, grid%rvblten,             &
197                         grid%rqvblten, grid%rqcblten, grid%rqiblten,           &
198                         grid%rthcuten, grid%rqvcuten, grid%rqccuten,           &
199                         grid%rqrcuten, grid%rqicuten, grid%rqscuten,           &
200                         grid%rthften,  grid%rqvften,                           &
201                         grid%rucuten,  grid%rvcuten,                           &    
202                         grid%RUNDGDTEN, grid%RVNDGDTEN, grid%RTHNDGDTEN,       &
203                         grid%RPHNDGDTEN,grid%RQVNDGDTEN, grid%RMUNDGDTEN,      &
204                         ids, ide, jds, jde, kds, kde,           &
205                         ims, ime, jms, jme, kms, kme,           &
206                         grid%i_start(ij), grid%i_end(ij),       &
207                         grid%j_start(ij), grid%j_end(ij),       &
208                         k_start, k_end                         )
209       ENDDO
210       !$OMP END PARALLEL DO
212 BENCH_END(phy_prep_tim)
214 ! radiation
215      CALL domain_clock_get( grid, current_time=currentTime, &
216                             current_timestr=mesg )
217      CALL WRFU_TimeGet( currentTime, YY=yr, dayOfYear=day, H=hr, M=minute, S=sec, rc=rc)
218          IF( rc/= WRFU_SUCCESS)THEN
219          CALL wrf_error_fatal('WRFU_TimeGet failed')
220          ENDIF
222 ! this driver is only needed to handle non-local shadowing effects
223       CALL pre_radiation_driver ( grid, config_flags                        &
224      &        ,itimestep=grid%itimestep, ra_call_offset=grid%ra_call_offset    &
225      &        ,XLAT=grid%xlat, XLONG=grid%xlong, GMT=grid%gmt                  &
226      &        ,julian=grid%julian, xtime=grid%xtime, RADT=grid%radt            &
227      &        ,STEPRA=grid%stepra                                              &
228      &        ,ht=grid%ht,dx=grid%dx,dy=grid%dy,sina=grid%sina,cosa=grid%cosa  &
229      &        ,shadowmask=grid%shadowmask,slope_rad=config_flags%slope_rad     &
230      &        ,topo_shading=config_flags%topo_shading                          &
231      &        ,shadlen=config_flags%shadlen,ht_shad=grid%ht_shad,ht_loc=ht_loc &
232      &        ,ht_shad_bxs=grid%ht_shad_bxs, ht_shad_bxe=grid%ht_shad_bxe      &
233      &        ,ht_shad_bys=grid%ht_shad_bys, ht_shad_bye=grid%ht_shad_bye      &
234      &        ,nested=config_flags%nested, min_ptchsz=grid%min_ptchsz          &
235      &        ,spec_bdy_width=config_flags%spec_bdy_width                      &
236             ! indexes
237      &        ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde          &
238      &        ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme          &
239      &        ,IPS=ips,IPE=ipe, JPS=jps,JPE=jpe, KPS=kps,KPE=kpe          &
240      &        ,i_start=grid%i_start,i_end=min(grid%i_end, ide-1)          &
241      &        ,j_start=grid%j_start,j_end=min(grid%j_end, jde-1)          &
242      &        ,kts=k_start, kte=min(k_end,kde-1)                          &
243      &        ,num_tiles=grid%num_tiles                                   )
245       CALL wrf_debug ( 200 , ' call radiation_driver' )
246 BENCH_START(rad_driver_tim)
248       CALL radiation_driver(                                                  &
249      &         ACFRCV=grid%acfrcv      ,ACFRST=grid%acfrst      ,ALBEDO=grid%albedo  &
250      &        ,CFRACH=grid%cfrach      ,CFRACL=grid%cfracl      ,CFRACM=grid%cfracm  &
251      &        ,CUPPT=grid%cuppt        ,CZMEAN=grid%czmean      ,DT=grid%dt          &
252      &        ,DZ8W=dz8w               ,EMISS=grid%emiss        ,GLW=grid%glw        &
253      &        ,GMT=grid%gmt            ,GSW=grid%gsw            ,HBOT=grid%hbot      &
254      &        ,HTOP=grid%htop          ,HBOTR=grid%hbotr        ,HTOPR=grid%htopr    &
255      &        ,ICLOUD=config_flags%icloud                                            &
256      &        ,ITIMESTEP=grid%itimestep,JULDAY=grid%julday      , JULIAN=grid%julian &
257      &        ,JULYR=grid%julyr        ,LW_PHYSICS=config_flags%ra_lw_physics        &
258      &        ,NCFRCV=grid%ncfrcv      ,NCFRST=grid%ncfrst      ,NPHS=1              &
259      &        ,P8W=grid%p_hyd_w        ,P=grid%p_hyd            ,PI=pi_phy           &
260      &        ,RADT=grid%radt          ,RA_CALL_OFFSET=grid%ra_call_offset           &
261      &        ,RHO=rho                 ,RLWTOA=grid%rlwtoa                           &
262      &        ,RSWTOA=grid%rswtoa      ,RTHRATEN=grid%rthraten                       &
263      &        ,RTHRATENLW=grid%rthratenlw       ,RTHRATENSW=grid%rthratensw          &
264      &        ,SNOW=grid%snow          ,STEPRA=grid%stepra      ,SWDOWN=grid%swdown  &
265      &        ,SWDOWNC=grid%swdownc    ,SW_PHYSICS=config_flags%ra_sw_physics        &
266      &        ,T8W=t8w                 ,T=grid%t_phy           ,TAUCLDC=grid%taucldc &
267      &        ,TAUCLDI=grid%taucldi    ,TSK=grid%tsk            ,VEGFRA=grid%vegfra  &
268      &        ,WARM_RAIN=grid%warm_rain ,XICE=grid%xice         ,XLAND=grid%xland    &
269      &        ,XLAT=grid%xlat          ,XLONG=grid%xlong        ,YR=yr               &
270 !Optional solar variables
271      &        ,DECLINX=grid%declin ,SOLCONX=grid%solcon ,COSZEN=grid%coszen ,HRANG=grid%hrang    &
272      &        , CEN_LAT=grid%cen_lat                                      &
273      &        ,Z=grid%z                                                   &
274      &        ,LEVSIZ=grid%levsiz, N_OZMIXM=num_ozmixm                    &
275      &        ,N_AEROSOLC=num_aerosolc                                    &
276      &        ,PAERLEV=grid%paerlev                                       &
277      &        ,CAM_ABS_DIM1=grid%cam_abs_dim1, CAM_ABS_DIM2=grid%cam_abs_dim2 &
278      &        ,CAM_ABS_FREQ_S=grid%cam_abs_freq_s                         &
279      &        ,XTIME=grid%xtime                                                &
280               ,CURR_SECS=curr_secs, ADAPT_STEP_FLAG=adapt_step_flag       &
281             ! indexes
282      &        ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde          &
283      &        ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme          &
284      &        ,i_start=grid%i_start,i_end=min(grid%i_end, ide-1)          &
285      &        ,j_start=grid%j_start,j_end=min(grid%j_end, jde-1)          &
286      &        ,kts=k_start, kte=min(k_end,kde-1)                          &
287      &        ,num_tiles=grid%num_tiles                                   &
288             ! Optional
289 !JJS 20101020 vvvvv
290      &        , TLWDN=grid%tlwdn, TLWUP=grid%tlwup                        & ! goddard schemes
291      &        , SLWDN=grid%slwdn, SLWUP=grid%slwup                        & ! goddard schemes
292      &        , TSWDN=grid%tswdn, TSWUP=grid%tswup                        & ! goddard schemes
293      &        , SSWDN=grid%sswdn, SSWUP=grid%sswup                        & ! goddard schemes
294 !JJS 20101020 ^^^^^
296      &        , CLDFRA=grid%cldfra                                        &
297      &        , PB=grid%pb                                                     &
298      &        , F_ICE_PHY=grid%f_ice_phy,F_RAIN_PHY=grid%f_rain_phy                 &
299      &        , QV=moist(ims,kms,jms,P_QV), F_QV=F_QV                     &
300      &        , QC=moist(ims,kms,jms,P_QC), F_QC=F_QC                     &
301      &        , QR=moist(ims,kms,jms,P_QR), F_QR=F_QR                     &
302      &        , QI=moist(ims,kms,jms,P_QI), F_QI=F_QI                     &
303      &        , QS=moist(ims,kms,jms,P_QS), F_QS=F_QS                     &
304      &        , QG=moist(ims,kms,jms,P_QG), F_QG=F_QG                     &
305      &        , QNDROP=scalar(ims,kms,jms,P_QNDROP), F_QNDROP=F_QNDROP    &
306      &        ,ACSWUPT=grid%acswupt    ,ACSWUPTC=grid%acswuptc            &
307      &        ,ACSWDNT=grid%acswdnt    ,ACSWDNTC=grid%acswdntc            &
308      &        ,ACSWUPB=grid%acswupb    ,ACSWUPBC=grid%acswupbc            &
309      &        ,ACSWDNB=grid%acswdnb    ,ACSWDNBC=grid%acswdnbc            &
310      &        ,ACLWUPT=grid%aclwupt    ,ACLWUPTC=grid%aclwuptc            &
311      &        ,ACLWDNT=grid%aclwdnt    ,ACLWDNTC=grid%aclwdntc            &
312      &        ,ACLWUPB=grid%aclwupb    ,ACLWUPBC=grid%aclwupbc            &
313      &        ,ACLWDNB=grid%aclwdnb    ,ACLWDNBC=grid%aclwdnbc            &
314      &        ,SWUPT=grid%swupt    ,SWUPTC=grid%swuptc                    &
315      &        ,SWDNT=grid%swdnt    ,SWDNTC=grid%swdntc                    &
316      &        ,SWUPB=grid%swupb    ,SWUPBC=grid%swupbc                    &
317      &        ,SWDNB=grid%swdnb    ,SWDNBC=grid%swdnbc                    &
318      &        ,LWUPT=grid%lwupt    ,LWUPTC=grid%lwuptc                    &
319      &        ,LWDNT=grid%lwdnt    ,LWDNTC=grid%lwdntc                    &
320      &        ,LWUPB=grid%lwupb    ,LWUPBC=grid%lwupbc                    &
321      &        ,LWDNB=grid%lwdnb    ,LWDNBC=grid%lwdnbc                    &
322      &        ,LWCF=grid%lwcf                                                  &
323      &        ,SWCF=grid%swcf                                                  &
324      &        ,OLR=grid%olr                                                    &
325      &        ,OZMIXM=grid%ozmixm, PIN=grid%pin                                     &
326      &        ,M_PS_1=grid%m_ps_1, M_PS_2=grid%m_ps_2, AEROSOLC_1=grid%aerosolc_1        &
327      &        ,AEROSOLC_2=grid%aerosolc_2, M_HYBI0=grid%m_hybi                      &
328      &        ,ABSTOT=grid%abstot, ABSNXT=grid%absnxt, EMSTOT=grid%emstot                &
329 #ifdef WRF_CHEM
330      &        ,CU_RAD_FEEDBACK=config_flags%cu_rad_feedback                &
331      &        ,AER_RA_FEEDBACK=config_flags%aer_ra_feedback                &
332      &        ,QC_ADJUST=grid%GD_CLOUD_B , QI_ADJUST=grid%GD_CLOUD2_B         &
333      &        ,PM2_5_DRY=grid%pm2_5_dry, PM2_5_WATER=grid%pm2_5_water               &
334      &        ,PM2_5_DRY_EC=grid%pm2_5_dry_ec                                  &
335      &        ,TAUAER300=grid%tauaer1, TAUAER400=grid%tauaer2 & ! jcb
336      &        ,TAUAER600=grid%tauaer3, TAUAER999=grid%tauaer4 & ! jcb
337      &        ,GAER300=grid%gaer1, GAER400=grid%gaer2, GAER600=grid%gaer3, GAER999=grid%gaer4 & ! jcb
338      &        ,WAER300=grid%waer1, WAER400=grid%waer2, WAER600=grid%waer3, WAER999=grid%waer4 & ! jcb
339 #endif
340      &         ,slope_rad=config_flags%slope_rad,topo_shading=config_flags%topo_shading     &
341      &         ,shadowmask=grid%shadowmask,ht=grid%ht,dx=grid%dx,dy=grid%dy    )
343 BENCH_END(rad_driver_tim)
345 !********* Surface driver
346 ! surface
348 BENCH_START(surf_driver_tim)
350 !-----------------------------------------------------------------
351 ! urban related variable are added to arguments of surface_driver
352 !-----------------------------------------------------------------
353       num_roof_layers = grid%num_soil_layers !urban
354       num_wall_layers = grid%num_soil_layers !urban
355       num_road_layers = grid%num_soil_layers !urban
356       CALL nl_get_iswater(grid%id, iswater)
357       CALL nl_get_isurban(grid%id, isurban)
358       call nl_get_mminlu(grid%id, mminlu)
360       CALL wrf_debug ( 200 , ' call surface_driver' )
362       CALL surface_driver(                                                &
363      &         ACGRDFLX=grid%acgrdflx  ,ACHFX=grid%achfx        ,ACLHF=grid%aclhf        &
364      &        ,ACSNOM=grid%acsnom      ,ACSNOW=grid%acsnow      ,AKHS=grid%akhs          &
365      &        ,AKMS=grid%akms          ,ALBBCK=grid%albbck      ,ALBEDO=grid%albedo      &
366      &        ,EMBCK=grid%embck                                                          &
367      &        ,BR=br              ,CANWAT=grid%canwat      ,CHKLOWQ=chklowq    &
368      &        ,CT=grid%ct              ,DT=grid%dt         ,DX=grid%dx         &
369      &        ,DZ8W=dz8w          ,DZS=grid%dzs            ,FLHC=grid%flhc          &
370      &        ,FLQC=grid%flqc          ,GLW=grid%glw            ,GRDFLX=grid%grdflx      &
371      &        ,GSW=grid%gsw    ,SWDOWN=grid%swdown        ,GZ1OZ0=gz1oz0      ,HFX=grid%hfx              &
372      &        ,HT=grid%ht              ,IFSNOW=config_flags%ifsnow      ,ISFFLX=config_flags%isfflx      &
373      &        ,FRACTIONAL_SEAICE=config_flags%fractional_seaice           &
374      &        ,TICE2TSK_IF2COLD=config_flags%tice2tsk_if2cold             &
375      &        ,ISLTYP=grid%isltyp      ,ITIMESTEP=grid%itimestep, JULIAN_IN=grid%julian                  &
376      &        ,IVGTYP=grid%ivgtyp      ,LH=grid%lh              ,LOWLYR=grid%lowlyr      &
377      &        ,MAVAIL=grid%mavail      ,NUM_SOIL_LAYERS=config_flags%num_soil_layers        &
378      &        ,P8W=grid%p_hyd_w            ,PBLH=grid%pblh          ,PI_PHY=pi_phy      &
379      &        ,PSFC=grid%psfc          ,PSHLTR=grid%pshltr      ,PSIH=psih          &
380      &        ,BLDT=grid%bldt     ,CURR_SECS=curr_secs, ADAPT_STEP_FLAG=adapt_step_flag  &
381      &        ,PSIM=psim          ,P_PHY=grid%p_hyd        ,Q10=grid%q10            &
382      &        ,Q2=grid%q2              ,QFX=grid%qfx            ,QSFC=grid%qsfc          &
383      &        ,QSHLTR=grid%qshltr      ,QZ0=grid%qz0            ,RAINCV=grid%raincv      &
384      &        ,RA_LW_PHYSICS=config_flags%ra_lw_physics            ,RHO=rho            &
385      &        ,RMOL=grid%rmol          ,SFCEVP=grid%sfcevp      ,SFCEXC=grid%sfcexc      &
386      &        ,SFCRUNOFF=grid%sfcrunoff                                        &
387      &        ,SF_SFCLAY_PHYSICS=config_flags%sf_sfclay_physics                        &
388      &        ,SF_SURFACE_PHYSICS=config_flags%sf_surface_physics  ,SH2O=grid%sh2o          &
389      &        ,SHDMAX=grid%shdmax      ,SHDMIN=grid%shdmin      ,SMOIS=grid%smois        &
390      &        ,SMSTAV=grid%smstav      ,SMSTOT=grid%smstot      ,SNOALB=grid%snoalb      &
391      &        ,SNOW=grid%snow          ,SNOWC=grid%snowc        ,SNOWH=grid%snowh        &
392      &        ,SMCREL=grid%smcrel                                                        &
393      &        ,SST=grid%sst            ,SST_UPDATE=grid%sst_update                  &
394      &        ,SSTSK=grid%sstsk        ,DTW=grid%dtw            ,SST_SKIN=grid%sst_skin  &
395      &        ,STEPBL=grid%stepbl      ,TH10=grid%th10          ,TH2=grid%th2            &
396      &        ,THZ0=grid%thz0          ,TH_PHY=th_phy      ,TKE_MYJ=grid%tke_myj    &
397      &        ,TMN=grid%tmn            ,TSHLTR=grid%tshltr      ,TSK=grid%tsk            &
398      &        ,TYR=grid%tyr            ,TYRA=grid%tyra          ,TDLY=grid%tdly          &
399      &        ,TLAG=grid%tlag          ,LAGDAY=config_flags%lagday      ,NYEAR=grid%nyear        &
400      &        ,NDAY=grid%nday          ,TMN_UPDATE=grid%tmn_update      ,YR=yr            &
401      &        ,TSLB=grid%tslb          ,T_PHY=t_phy        ,U10=grid%u10            &
402      &        ,URATX=grid%uratx        ,VRATX=grid%vratx   ,TRATX=grid%tratx        &
403      &        ,UDRUNOFF=grid%udrunoff  ,UST=grid%ust       ,UZ0=grid%uz0            &
404      &        ,U_FRAME=grid%u_frame    ,U_PHY=u_phy        ,V10=grid%v10            &
405      &        ,VEGFRA=grid%vegfra      ,VZ0=grid%vz0       ,V_FRAME=grid%v_frame    &
406      &        ,V_PHY=v_phy             ,WARM_RAIN=grid%warm_rain                    &
407      &        ,WSPD=wspd               ,XICE=grid%xice     ,XLAND=grid%xland        &
408      &        ,Z0=grid%z0              ,Z=grid%z        ,ZNT=grid%znt            &
409      &        ,ZS=grid%zs              ,XICEM=grid%xicem   ,ISICE=grid%landuse_isice&
410      &        ,USTM=grid%ustm          ,CK=grid%ck         ,CKA=grid%cka            &
411      &                                 ,CD=grid%cd         ,CDA=grid%cda            &
412      &        ,ISFTCFLX=config_flags%isftcflx, IZ0TLND=config_flags%iz0tlnd         &
413      &        ,OMLCALL=config_flags%omlcall ,OML_HML0=config_flags%oml_hml0 ,OML_GAMMA=config_flags%oml_gamma &
414      &        ,TML=grid%tml, T0ML=grid%t0ml, HML=grid%hml, H0ML=grid%h0ml, HUML=grid%huml, HVML=grid%hvml, F=grid%f &
415      &        ,TMOML=grid%TMOML,ISWATER=iswater &
416      &        ,SLOPE_RAD=config_flags%slope_rad,TOPO_SHADING=config_flags%topo_shading & ! solar
417      &        ,SHADOWMASK=grid%shadowmask                                              & ! solar
418      &        ,SLOPE=grid%slope, SLP_AZI=grid%slp_azi, SWNORM=grid%swnorm              & ! solar
419      &        ,DECLIN=grid%declin ,SOLCON=grid%solcon ,COSZEN=grid%coszen ,HRANG=grid%hrang    &
420      &        ,xlat_urb2d=grid%XLAT                                       & !I urban
421      &        ,NUM_ROOF_LAYERS=num_roof_layers                            & !I urban
422      &        ,NUM_WALL_LAYERS=num_wall_layers                            & !I urban
423      &        ,NUM_ROAD_LAYERS=num_road_layers                            &
424      &        ,DZR=grid%dzr ,DZB=grid%dzb ,DZG=grid%dzg                   & !I urban
425      &        ,TR_URB2D=grid%tr_urb2d ,TB_URB2D=grid%tb_urb2d             &
426      &        ,TG_URB2D=grid%tg_urb2d                                     & !H urban
427      &        ,TC_URB2D=grid%tc_urb2d ,QC_URB2D=grid%qc_urb2d             & !H urban
428      &        ,UC_URB2D=grid%uc_urb2d                                     & !H urban
429      &        ,XXXR_URB2D=grid%xxxr_urb2d                                 &
430      &        ,XXXB_URB2D=grid%xxxb_urb2d                                 & !H urban
431      &        ,XXXG_URB2D=grid%xxxg_urb2d                                 &
432      &        ,XXXC_URB2D=grid%xxxc_urb2d                                 & !H urban
433      &        ,TRL_URB3D=grid%trl_urb3d   ,TBL_URB3D=grid%tbl_urb3d       & !H urban
434      &        ,TGL_URB3D=grid%tgl_urb3d                                   & !H urban
435      &        ,SH_URB2D=grid%sh_urb2d     ,LH_URB2D=grid%lh_urb2d         &
436      &        ,G_URB2D=grid%g_urb2d                                       & !H urban
437      &        ,RN_URB2D=grid%rn_urb2d     , TS_URB2D=grid%ts_urb2d        & !H urban
438      &        ,FRC_URB2D=grid%frc_urb2d                                   & !H urban
439      &        ,UTYPE_URB2D=grid%utype_urb2d                               & !H urban
440          ! Optional urban for BEP scheme
441      &        ,SF_URBAN_PHYSICS=config_flags%sf_urban_physics             &
442      &        ,NUM_URBAN_LAYERS=config_flags%num_urban_layers             & !multi-layer urban
443      &        ,TRB_URB4D=grid%trb_urb4d,TW1_URB4D=grid%tw1_urb4d          & !multi-layer urban
444      &        ,TW2_URB4D=grid%tw2_urb4d,TGB_URB4D=grid%tgb_urb4d          & !multi-layer urban
445      &        ,TLEV_URB3D=grid%tlev_urb3d                               & !multi-layer urban
446      &        ,QLEV_URB3D=grid%qlev_urb3d                               & !multi-layer urban
447      &        ,TW1LEV_URB3D=grid%tw1lev_urb3d                           & !multi-layer urban
448      &        ,TW2LEV_URB3D=grid%tw2lev_urb3d                           & !multi-layer urban
449      &        ,TGLEV_URB3D=grid%tglev_urb3d                             & !multi-layer urban
450      &        ,TFLEV_URB3D=grid%tflev_urb3d                             & !multi-layer urban
451      &        ,SF_AC_URB3D=grid%sf_ac_urb3d                             & !multi-layer urban
452      &        ,LF_AC_URB3D=grid%lf_ac_urb3d                             & !multi-layer urban
453      &        ,CM_AC_URB3D=grid%cm_ac_urb3d                             & !multi-layer urban
454      &        ,SFVENT_URB3D=grid%sfvent_urb3d                           & !multi-layer urban
455      &        ,LFVENT_URB3D=grid%lfvent_urb3d                           & !multi-layer urban
456      &        ,SFWIN1_URB3D=grid%sfwin1_urb3d                           & !multi-layer urban
457      &        ,SFWIN2_URB3D=grid%sfwin2_urb3d                           & !multi-layer urban
458      &        ,SFW1_URB3D=grid%sfw1_urb3d,SFW2_URB3D=grid%sfw2_urb3d      & !multi-layer urban
459      &        ,SFR_URB3D=grid%sfr_urb3d,SFG_URB3D=grid%sfg_urb3d          & !multi-layer urban
460      &        ,GMT=grid%gmt,XLAT=grid%xlat,XLONG=grid%xlong,JULDAY=grid%julday  &
461      &        ,A_U_BEP=grid%a_u_bep,A_V_BEP=grid%a_v_bep,A_T_BEP=grid%a_t_bep   &
462      &        ,A_Q_BEP=grid%a_q_bep                                             &
463      &        ,B_U_BEP=grid%b_u_bep,B_V_BEP=grid%b_v_bep,B_T_BEP=grid%b_t_bep   &
464      &        ,B_Q_BEP=grid%b_q_bep                                             &
465      &        ,SF_BEP=grid%sf_bep,VL_BEP=grid%vl_bep                            &
466      &        ,A_E_BEP=grid%a_e_bep,B_E_BEP=grid%b_e_bep,DLG_BEP=grid%dlg_bep   &
467      &        ,DL_U_BEP=grid%dl_u_bep                                           &
468      &        ,CMR_SFCDIF=grid%cmr_sfcdif, CHR_SFCDIF=grid%chr_sfcdif     & !I/O urban
469      &        ,CMC_SFCDIF=grid%cmc_sfcdif, CHC_SFCDIF=grid%chc_sfcdif     & !I/O urban
470            ! P-X LSM Variables
471      &        ,LANDUSEF=grid%landusef, SOILCTOP=grid%soilctop             &   ! P-X LSM
472      &        ,SOILCBOT=grid%soilcbot                                     &   ! P-X LSM
473      &        ,RA=grid%ra, RS=grid%rs, LAI=grid%lai                       &   ! P-X LSM
474      &        ,NLCAT=grid%num_land_cat,  NSCAT=grid%num_soil_cat          &   ! P-X LSM
475      &        ,VEGF_PX=grid%vegf_px, SNOWNCV=grid%snowncv                 &   ! P-X LSM
476      &        ,ANAL_INTERVAL=config_flags%auxinput9_interval_s+config_flags%auxinput9_interval_m*60  &   ! P-X LSM
477      &        ,PXLSM_SMOIS_INIT=config_flags%pxlsm_smois_init             &   ! P-X LSM
478      &        ,PXLSM_SOIL_NUDGE=config_flags%pxlsm_soil_nudge             &   ! P-X LSM
479            ! Optional PX LSM nudging
480      &        ,t2_ndg_old=grid%t2_ndg_old                  &
481      &        ,q2_ndg_old=grid%q2_ndg_old                  &
482      &        ,t2_ndg_new=grid%t2_ndg_new                  &
483      &        ,q2_ndg_new=grid%q2_ndg_new                  &
484      &        ,sn_ndg_old=grid%sn_ndg_old                  &
485      &        ,sn_ndg_new=grid%sn_ndg_new                  &
486            ! Indexes
487      &        ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde          &
488      &        ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme          &
489      &        , I_START=grid%i_start,I_END=min(grid%i_end, ide-1)         &
490      &        , J_START=grid%j_start,J_END=min(grid%j_end, jde-1)         &
491      &        , KTS=k_start, KTE=min(k_end,kde-1)                         &
492      &        , NUM_TILES=grid%num_tiles                                  &
493           ! Variables required by TEMF PBL - WA 1/7/09
494               ,te_temf=grid%te_temf,hd_temf=grid%hd_temf                  &
495               ,fCor=grid%f,exch_temf=exch_temf                              &
496           ! Variables required by IDEAL SCM sfc scheme - WA 1/6/10
497               ,hfx_force=grid%hfx_force,lh_force=grid%lh_force            &
498               ,tsk_force=grid%tsk_force                                   &
499               ,hfx_force_tend=grid%hfx_force_tend                         &
500               ,lh_force_tend=grid%lh_force_tend                           &
501               ,tsk_force_tend=grid%tsk_force_tend                         &
502            ! Optional
503      &        ,QV_CURR=moist(ims,kms,jms,P_QV), F_QV=F_QV                 &
504      &        ,QC_CURR=moist(ims,kms,jms,P_QC), F_QC=F_QC                 &
505      &        ,QR_CURR=moist(ims,kms,jms,P_QR), F_QR=F_QR                 &
506      &        ,QI_CURR=moist(ims,kms,jms,P_QI), F_QI=F_QI                 &
507      &        ,QS_CURR=moist(ims,kms,jms,P_QS), F_QS=F_QS                 &
508      &        ,QG_CURR=moist(ims,kms,jms,P_QG), F_QG=F_QG                 &
509      &        ,CAPG=grid%capg, EMISS=grid%emiss, HOL=hol,MOL=grid%mol     &
510      &        ,T2OBS=grid%t2obs, Q2OBS=grid%q2obs                         &
511      &        ,RAINBL=grid%rainbl,SR=grid%sr                                              &
512      &        ,RAINNCV=grid%rainncv,REGIME=grid%regime,T2=grid%t2,THC=grid%thc            &
513      &        ,QSG=grid%qsg,QVG=grid%qvg,QCG=grid%qcg,SOILT1=grid%soilt1,TSNAV=grid%tsnav & ! ruc lsm
514      &        ,SMFR3D=grid%smfr3d,KEEPFR3DFLAG=grid%keepfr3dflag,DEW=grid%dew             & ! ruc lsm
515      &        ,POTEVP=grid%POTEVP, SNOPCX=grid%SNOPCX, SOILTB=grid%SOILTB                 & ! ruc lsm
516      &        ,ISURBAN=isurban, MMINLU=TRIM(mminlu)                       &
517      &        ,SNOTIME = grid%SNOTIME                                     &
518      &        ,RDLAI2D=config_flags%rdlai2d                               &
519      &        ,usemonalb=config_flags%usemonalb                           &
520      &        ,NOAHRES=grid%noahres                                       &
521 !mynn mp@
522      &         ,ch=grid%ch,tsq=grid%tsq,qsq=grid%qsq,cov=grid%cov &
523      &                                                              )
524 BENCH_END(surf_driver_tim)
526 !*********
527 ! pbl
529       CALL wrf_debug ( 200 , ' call pbl_driver' )
530 BENCH_START(pbl_driver_tim)
531       CALL pbl_driver(                                                              &
532      &         AKHS=grid%akhs          ,AKMS=grid%akms                              &
533      &        ,BL_PBL_PHYSICS=config_flags%bl_pbl_physics                           &
534      &        ,BLDT=grid%bldt, CURR_SECS=curr_secs, ADAPT_STEP_FLAG=adapt_step_flag &
535      &        ,BR=br              ,CHKLOWQ=chklowq    ,CT=grid%ct                   &
536      &        ,DT=grid%dt              ,DX=grid%dx              ,DZ8W=dz8w          &
537      &        ,EL_MYJ=grid%el_myj      ,EXCH_H=grid%exch_h     ,EXCH_M=grid%exch_m   &
538      &        ,F=grid%f  ,GRDFLX=grid%grdflx      &
539      &        ,GZ1OZ0=gz1oz0      ,HFX=grid%hfx            ,HT=grid%ht              &
540      &        ,ID=grid%id         ,ITIMESTEP=grid%itimestep     ,KPBL=grid%kpbl          &
541      &        ,LH=grid%lh              ,LOWLYR=grid%lowlyr      ,P8W=grid%p_hyd_w   &
542      &        ,PBLH=grid%pblh          ,PI_PHY=pi_phy      ,PSIH=psih          &
543      &        ,PSIM=psim          ,P_PHY=grid%p_hyd        ,QFX=grid%qfx            &
544      &        ,QSFC=grid%qsfc          ,QZ0=grid%qz0  ,MIXHT=mixht                  &
545      &        ,RA_LW_PHYSICS=config_flags%ra_lw_physics                   &
546      &        ,RHO=rho            ,RQCBLTEN=grid%rqcblten  ,RQIBLTEN=grid%rqiblten  &
547      &        ,RQVBLTEN=grid%rqvblten  ,RTHBLTEN=grid%rthblten  ,RUBLTEN=grid%rublten    &
548      &        ,RVBLTEN=grid%rvblten    ,SNOW=grid%snow          ,STEPBL=grid%stepbl      &
549      &        ,THZ0=grid%thz0          ,TH_PHY=th_phy      ,TKE_MYJ=grid%tke_myj    &
550      &        ,TSK=grid%tsk            ,T_PHY=grid%t_phy        ,UST=grid%ust       &
551      &        ,U10=grid%u10 ,UZ0=grid%uz0      ,U_FRAME=grid%u_frame    ,U_PHY=u_phy        &
552      &        ,V10=grid%v10 ,VZ0=grid%vz0      ,V_FRAME=grid%v_frame    ,V_PHY=v_phy        &
553               ,T2=grid%t2 &
554      &        ,WARM_RAIN=grid%warm_rain                    ,WSPD=wspd          &
555      &        ,XICE=grid%xice          ,XLAND=grid%xland        ,Z=grid%z                &
556      &        ,ZNT=grid%znt                                                    &
557 ! variables added for BEP
558      &          ,FRC_URB2D=grid%frc_urb2d                                                  &
559      &          ,A_U_BEP=grid%a_u_bep,A_V_BEP=grid%a_v_bep,A_T_BEP=grid%a_t_bep          &
560      &          ,A_Q_BEP=grid%a_q_bep                                                    &
561      &          ,B_U_BEP=grid%b_u_bep,B_V_BEP=grid%b_v_bep,B_T_BEP=grid%b_t_bep          &
562      &          ,B_Q_BEP=grid%b_q_bep                                                    &
563      &          ,SF_BEP=grid%sf_bep,VL_BEP=grid%vl_bep                                   &
564      &          ,A_E_BEP=grid%a_e_bep,B_E_BEP=grid%b_e_bep,DLG_BEP=grid%dlg_bep          &
565      &          ,DL_U_BEP=grid%dl_u_bep                                                  &
566      &          ,SF_SFCLAY_PHYSICS=config_flags%sf_sfclay_physics                        &
567      &          ,SF_URBAN_PHYSICS=config_flags%sf_urban_physics                          &
568 ! Bep changes end
569 ! add tke_pbl, and turbulent fluxes
570      &          ,TKE_PBL=grid%tke_pbl,EL_PBL=grid%el_pbl,WU_TUR=grid%wu_tur,WV_tur=grid%wv_tur,WT_tur=grid%wt_tur,WQ_tur=grid%wq_tur   &
571 ! end add tke_pbl, and turbulent fluxes
572      &        ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde          &
573      &        ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme          &
574      &        ,I_START=grid%i_start,I_END=min(grid%i_end, ide-1)          &
575      &        ,J_START=grid%j_start,J_END=min(grid%j_end, jde-1)          &
576      &        ,KTS=k_start, KTE=min(k_end,kde-1)                          &
577      &        ,NUM_TILES=grid%num_tiles                                   &
578           ! Variables Required by ACM PBL  - jp
579      &        ,ZNU=grid%znu,ZNW=grid%znw,MUT=grid%mut,P_TOP=grid%p_top    &
580           ! Variables required by TEMF PBL - WA 9/9/08
581               ,te_temf=grid%te_temf                                 &
582               ,kh_temf=grid%kh_temf,km_temf=grid%km_temf            &
583               ,shf_temf=grid%shf_temf,qf_temf=grid%qf_temf          &
584               ,uw_temf=grid%uw_temf,vw_temf=grid%vw_temf            &
585               ,hd_temf=grid%hd_temf,lcl_temf=grid%lcl_temf          &
586               ,wupd_temf=grid%wupd_temf,mf_temf=grid%mf_temf          &
587               ,thup_temf=grid%thup_temf,qtup_temf=grid%qtup_temf          &
588               ,qlup_temf=grid%qlup_temf          &
589               ,cf3d_temf=grid%cf3d_temf,cfm_temf=grid%cfm_temf          &
590               ,hct_temf=grid%hct_temf                               &
591               ,flhc=grid%flhc,flqc=grid%flqc                        &
592               ,exch_temf=exch_temf                      &
593           ! optional
594      &        ,QV_CURR=moist(ims,kms,jms,P_QV), F_QV=F_QV                 &
595      &        ,QC_CURR=moist(ims,kms,jms,P_QC), F_QC=F_QC                 &
596      &        ,QR_CURR=moist(ims,kms,jms,P_QR), F_QR=F_QR                 &
597      &        ,QI_CURR=moist(ims,kms,jms,P_QI), F_QI=F_QI                 &
598      &        ,QS_CURR=moist(ims,kms,jms,P_QS), F_QS=F_QS                 &
599      &        ,QG_CURR=moist(ims,kms,jms,P_QG), F_QG=F_QG                 &
600      &        ,HOL=HOL, MOL=grid%mol, REGIME=grid%REGIME                  &
601 !mynn mp@
602      &        ,QKE=scalar(ims,kms,jms,P_qke), tsq=grid%tsq, qsq=grid%qsq, cov=grid%cov     &
603      &        ,rmol=grid%rmol, ch=grid%ch                                 &
604      &        ,qcg=grid%qcg, grav_settling=grid%grav_settling             &
605 !    &        ,K_m=grid%K_m, K_h=grid%K_h, K_q=grid%K_q                   &
606 !GWD for ARW
607      &        ,GWD_OPT=config_flags%gwd_opt &
608      &        ,DUSFCG=grid%dusfcg,DVSFCG=grid%dvsfcg &
609      &        ,VAR2D=grid%var2d,OC12D=grid%oc12d     &
610      &        ,OA1=grid%oa1,OA2=grid%oa2,OA3=grid%oa3,OA4=grid%oa4        &
611      &        ,OL1=grid%ol1,OL2=grid%ol2,OL3=grid%ol3,OL4=grid%ol4        &
612 ! For Wind Turbine Drag Parameterizations
613      &        ,phb=grid%phb                                               &
614      &        ,XLAT_U=grid%xlat_u,XLONG_U=grid%xlong_u                    &
615      &        ,XLAT_V=grid%xlat_v,XLONG_V=grid%xlong_v                    &
616      &        )
617                                                          
619 BENCH_END(pbl_driver_tim)
621 !*****
622 ! fire 
624 ! Jan Mandel's call to SFIRE
626       IF ((grid%sr_x > 0 .OR. grid%sr_y > 0) .AND. config_flags%ifire == 2) THEN
628 BENCH_START(fire_driver_tim)
629         if(config_flags%ifire.eq.2)then 
630             ! initialization moved to start_em:start_domain_em
631 !            if(grid%initestep.eq.1) &
632 !            call sfire_driver_em_init (  grid , config_flags    &
633 !            ,ids,ide, kds,kde, jds,jde                              &
634 !            ,ims,ime, kms,kme, jms,jme                              &
635 !            ,ips,ipe, kps,kpe, jps,jpe  )
636             ! one timestep of the fire model
637             call sfire_driver_em_step (  grid , config_flags    &
638             ,ids,ide, kds,kde, jds,jde                              &
639             ,ims,ime, kms,kme, jms,jme                              &
640             ,ips,ipe, kps,kpe, jps,jpe                              &
641             ,rho,grid%z_at_w,dz8w)
642         endif
644 BENCH_END(fire_driver_tim)
645        ENDIF
648 ! cumulus para.
650       CALL wrf_debug ( 200 , ' call cumulus_driver' )
652 #if ( WRF_DFI_RADAR == 1 )
653       do_capsupress=0
654       if (config_flags%dfi_radar == 1) then
655          if(grid%dfi_stage == DFI_FWD ) do_capsupress=1
656          if(grid%itimestep <= 31 .and. grid%dfi_stage == DFI_FST ) do_capsupress=1
657       endif
658 #endif
660 BENCH_START(cu_driver_tim)
661       CALL cumulus_driver(grid                                             &
662                  ! Prognostic variables
663      &             ,U=u_phy   ,V=v_phy   ,TH=th_phy  ,T=grid%t_phy                  &
664      &             ,W=grid%w_2     ,P=grid%p_hyd   ,PI=pi_phy  ,RHO=rho             &
665                  ! Other arguments
666      &             ,ITIMESTEP=grid%itimestep ,DT=grid%dt      ,DX=grid%dx                &
667      &             ,CUDT=grid%cudt,CURR_SECS=curr_secs,ADAPT_STEP_FLAG=adapt_step_flag &
668      &             ,RAINC=grid%rainc   ,RAINCV=grid%raincv   ,PRATEC=grid%pratec         &
669      &             , NCA=grid%nca                                         &
670      &             ,HTOP=grid%cutop     ,HBOT=grid%cubot       ,KPBL=grid%kpbl             &
671      &             ,DZ8W=dz8w     ,P8W=grid%p_hyd_w                                &
672      &             ,W0AVG=grid%w0avg   ,STEPCU=grid%stepcu                          &
673      &             ,CLDEFI=grid%cldefi ,LOWLYR=grid%lowlyr ,XLAND=grid%xland             &
674      &             ,APR_GR=grid%apr_gr ,APR_W=grid%apr_w   ,APR_MC=grid%apr_mc           &
675      &             ,APR_ST=grid%apr_st ,APR_AS=grid%apr_as ,APR_CAPMA=grid%apr_capma     &
676      &             ,APR_CAPME=grid%apr_capme          ,APR_CAPMI=grid%apr_capmi     &
677      &             ,MASS_FLUX=grid%mass_flux          ,XF_ENS=grid%xf_ens           &
678      &             ,PR_ENS=grid%pr_ens ,HT=grid%ht,EDT_OUT=grid%edt_out             &
679      &             ,imomentum=grid%imomentum,clos_choice=grid%clos_choice       &
680      &             ,ishallow=config_flags%ishallow                                  &
681      &             ,cugd_tten=grid%cugd_tten,cugd_qvten=grid%cugd_qvten,cugd_qcten=grid%cugd_qcten   &
682      &             ,cugd_ttens=grid%cugd_ttens,cugd_qvtens=grid%cugd_qvtens   &
683      &             ,ENSDIM=config_flags%ensdim ,MAXIENS=config_flags%maxiens ,MAXENS=config_flags%maxens         &
684      &             ,MAXENS2=config_flags%maxens2                ,MAXENS3=config_flags%maxens3       &
685      &             ,CU_ACT_FLAG=cu_act_flag   ,WARM_RAIN=grid%warm_rain        &
686      &             ,GSW=grid%gsw,cugd_avedx=config_flags%cugd_avedx &
687      &             ,k22_shallow=grid%k22_shallow,kbcon_shallow=grid%kbcon_shallow            &
688      &             ,ktop_shallow=grid%ktop_shallow,xmb_shallow=grid%xmb_shallow            &
689      &             ,PERIODIC_X=(config_flags%polar .OR. config_flags%periodic_x)  &
690      &             ,PERIODIC_Y=config_flags%periodic_y  &
691                  ! Selection flag
692      &             ,CU_PHYSICS=config_flags%cu_physics                    &
693      &             ,KFETA_TRIGGER=config_flags%kfeta_trigger              &
694                  ! Dimension arguments
695      &             ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde     &
696      &             ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme     &
697      &             ,IPS=ips,IPE=ipe, JPS=jps,JPE=jpe, KPS=kps,KPE=kpe     &
698      &             ,I_START=grid%i_start,I_END=min(grid%i_end, ide-1)     &
699      &             ,J_START=grid%j_start,J_END=min(grid%j_end, jde-1)     &
700      &             ,KTS=k_start, KTE=min(k_end,kde-1)                     &
701      &             ,NUM_TILES=grid%num_tiles                              &
702                  ! Moisture tendency arguments
703      &             ,RQVCUTEN=grid%rqvcuten , RQCCUTEN=grid%rqccuten                 &
704      &             ,RQSCUTEN=grid%rqscuten , RQICUTEN=grid%rqicuten                 &
705      &             ,RQRCUTEN=grid%rqrcuten , RQVBLTEN=grid%rqvblten                 &
706      &             ,RQVFTEN=grid%rqvften                                       &
707                  ! Other tendency arguments
708      &             ,RTHRATEN=grid%rthraten , RTHBLTEN=grid%rthblten                 &
709      &             ,RTHCUTEN=grid%rthcuten , RTHFTEN=grid%rthften                   &
710                  ! Moisture tracer arguments
711      &             ,QV_CURR=moist(ims,kms,jms,P_QV), F_QV=F_QV            &
712      &             ,QC_CURR=moist(ims,kms,jms,P_QC), F_QC=F_QC            &
713      &             ,QR_CURR=moist(ims,kms,jms,P_QR), F_QR=F_QR            &
714      &             ,QI_CURR=moist(ims,kms,jms,P_QI), F_QI=F_QI            &
715      &             ,QS_CURR=moist(ims,kms,jms,P_QS), F_QS=F_QS            &
716      &             ,QG_CURR=moist(ims,kms,jms,P_QG), F_QG=F_QG            &
717 ! Variables for Tiedtke and NSAS schemes
718      &             ,ZNU=grid%znu, QFX=grid%qfx                            &
719      &             ,RUCUTEN=grid%rucuten, RVCUTEN=grid%rvcuten            &
720      &             ,PBLH=grid%pblh ,HFX=grid%hfx                          &
721      &             ,MP_PHYSICS=config_flags%mp_physics                    &
722 #ifdef WRF_CHEM
723      &             ,GD_CLOUD=grid%GD_CLOUD,GD_CLOUD2=grid%GD_CLOUD2       &
724 #endif
725 #if ( WRF_DFI_RADAR == 1 )
726      &             ,DO_CAPSUPPRESS=do_capsupress                          &
727 #endif
728      &             ,cfu1=grid%cfu1,cfd1=grid%cfd1,dfu1=grid%dfu1,efu1=grid%efu1,dfd1=grid%dfd1,efd1=grid%efd1,f_flux=l_flux)
729 BENCH_END(cu_driver_tim)
731 ! this for calculating (G3 scheme only)  time averaged variables for online (WRF-CHem) or offline (other models) chem runs
733      if(config_flags%cu_diag.eq.1)then
734       !$OMP PARALLEL DO   &
735       !$OMP PRIVATE ( ij )
736       DO ij = 1 , grid%num_tiles
737            call convtrans_prep(grid%gd_cloud,grid%gd_cloud2,grid%gd_cloud_a,&
738      &          grid%gd_cloud_b,grid%raincv,grid%raincv_a,grid%raincv_b,     &
739      &          grid%gd_cldfr,moist,p_QV,p_QC,p_qi,T_PHY,P_PHY,num_moist,    &
740      &          grid%gd_cloud2_a,grid%gd_cloud2_b,grid%convtrans_avglen_m,&
741      &          adapt_step_flag,curr_secs,                &
742      &          grid%itimestep,grid%dt,                                      &
743      &          config_flags%cu_physics,                                     &
744      &          ids,ide, jds,jde, kds,kde,                                   &
745      &          ims,ime, jms,jme, kms,kme                                    &
746      &          ,ITS=grid%i_start(ij),ITE=min(grid%i_end(ij), ide-1)                 &
747      &          ,JTS=grid%j_start(ij),JTE=min(grid%j_end(ij), jde-1)                 &
748      &          ,KTS=k_start, KTE=min(k_end,kde-1))
749       ENDDO
750       !$OMP END PARALLEL DO
751      endif
754 ! JPH call force_scm to update bl tendencies
755       CALL force_scm(itimestep=grid%itimestep,dt=grid%dt                  &
756      &             ,scm_force=config_flags%scm_force                      &
757      &             ,dx=config_flags%scm_force_dx                          &
758      &             ,num_force_layers=grid%num_force_layers                &
759      &             ,scm_th_adv=config_flags%scm_th_adv                    &
760      &             ,scm_qv_adv=config_flags%scm_qv_adv                    &
761      &             ,scm_ql_adv=config_flags%scm_ql_adv                    &
762      &             ,scm_wind_adv=config_flags%scm_wind_adv                &
763      &             ,scm_vert_adv=config_flags%scm_vert_adv                &
764      &             ,scm_soilT_force=config_flags%scm_soilT_force          &
765      &             ,scm_soilQ_force=config_flags%scm_soilQ_force          &
766      &      ,scm_force_th_largescale=config_flags%scm_force_th_largescale &
767      &      ,scm_force_qv_largescale=config_flags%scm_force_qv_largescale &
768      &      ,scm_force_ql_largescale=config_flags%scm_force_ql_largescale &
769      &      ,scm_force_wind_largescale=config_flags%scm_force_wind_largescale &
770      &             ,u_base=grid%u_base,v_base=grid%v_base                 &
771      &             ,z_base=grid%z_base                                    &
772      &             ,z_force=grid%z_force,z_force_tend=grid%z_force_tend   &
773      &             ,u_g=grid%u_g,v_g=grid%v_g                             &
774      &             ,u_g_tend=grid%u_g_tend,v_g_tend=grid%v_g_tend         &
775      &             ,w_subs=grid%w_subs, w_subs_tend=grid%w_subs_tend      &
776      &             ,th_upstream_x=grid%th_upstream_x                      &
777      &             ,th_upstream_x_tend=grid%th_upstream_x_tend            &
778      &             ,th_upstream_y=grid%th_upstream_y                      &
779      &             ,th_upstream_y_tend=grid%th_upstream_y_tend            &
780      &             ,qv_upstream_x=grid%qv_upstream_x                      &
781      &             ,qv_upstream_x_tend=grid%qv_upstream_x_tend            &
782      &             ,qv_upstream_y=grid%qv_upstream_y                      &
783      &             ,qv_upstream_y_tend=grid%qv_upstream_y_tend            &
784      &             ,ql_upstream_x=grid%ql_upstream_x                      &
785      &             ,ql_upstream_x_tend=grid%ql_upstream_x_tend            &
786      &             ,ql_upstream_y=grid%ql_upstream_y                      &
787      &             ,ql_upstream_y_tend=grid%ql_upstream_y_tend            &
788      &             ,u_upstream_x=grid%u_upstream_x                        &
789      &             ,u_upstream_x_tend=grid%u_upstream_x_tend              &
790      &             ,u_upstream_y=grid%u_upstream_y                        &
791      &             ,u_upstream_y_tend=grid%u_upstream_y_tend              &
792      &             ,v_upstream_x=grid%v_upstream_x                        &
793      &             ,v_upstream_x_tend=grid%v_upstream_x_tend              &
794      &             ,v_upstream_y=grid%v_upstream_y                        &
795      &             ,v_upstream_y_tend=grid%v_upstream_y_tend              &
796      &             ,tau_x=grid%tau_x                                      &
797      &             ,tau_x_tend=grid%tau_x_tend                            &
798      &             ,tau_y=grid%tau_y                                      &
799      &             ,tau_y_tend=grid%tau_y_tend                            &
800      &             ,th_largescale=grid%th_largescale                      &
801      &             ,th_largescale_tend=grid%th_largescale_tend            &
802      &             ,qv_largescale=grid%qv_largescale                      &
803      &             ,qv_largescale_tend=grid%qv_largescale_tend            &
804      &             ,ql_largescale=grid%ql_largescale                      &
805      &             ,ql_largescale_tend=grid%ql_largescale_tend            &
806      &             ,u_largescale=grid%u_largescale                      &
807      &             ,u_largescale_tend=grid%u_largescale_tend            &
808      &             ,v_largescale=grid%v_largescale                      &
809      &             ,v_largescale_tend=grid%v_largescale_tend            &
810      &             ,tau_largescale=grid%tau_largescale                    &
811      &             ,tau_largescale_tend=grid%tau_largescale_tend          &
812      &             ,num_force_soil_layers=config_flags%num_force_soil_layers &
813      &             ,num_soil_layers=config_flags%num_soil_layers          &
814      &             ,soil_depth_force=grid%soil_depth_force                &
815      &             ,zs=grid%zs                                            &
816      &             ,tslb=grid%tslb,smois=grid%smois                       &
817      &             ,t_soil_forcing_val=grid%t_soil_forcing_val            &
818      &             ,t_soil_forcing_tend=grid%t_soil_forcing_tend          &
819      &             ,q_soil_forcing_val=grid%q_soil_forcing_val            &
820      &             ,q_soil_forcing_tend=grid%q_soil_forcing_tend          &
821      &             ,tau_soil=grid%tau_soil                                &
822      &             ,z=grid%z,z_at_w=grid%z_at_w                           &
823      &             ,th=th_phy, qv=moist(ims,kms,jms,P_QV)                 &
824      &             ,ql=moist(ims,kms,jms,P_QC)                            &
825      &             ,u=u_phy, v=v_phy                                      &
826      &             ,thten=grid%rthblten, qvten=grid%rqvblten              &
827      &             ,qlten=grid%rqcblten                                   &
828      &             ,uten=grid%rublten, vten=grid%rvblten                  &
829      &             ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde     &
830      &             ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme     &
831      &             ,IPS=ips,IPE=ipe, JPS=jps,JPE=jpe, KPS=kps,KPE=kpe     &
832      &             ,KTS=k_start, KTE=min(k_end,kde-1)                     &
833      &              )
835 #ifdef DM_PARALLEL
836 #     include "HALO_EM_FDDA_SFC.inc"
837 #endif
838       CALL wrf_debug ( 200 , ' call fddagd_driver' )
840 BENCH_START(fdda_driver_tim)
841       CALL fddagd_driver(itimestep=grid%itimestep,dt=grid%dt,xtime=grid%XTIME,      &
842                   id=grid%id,                                                       &
843                   RUNDGDTEN=grid%rundgdten,RVNDGDTEN=grid%rvndgdten,                &
844                   RTHNDGDTEN=grid%rthndgdten,RPHNDGDTEN=grid%rphndgdten,            &
845                   RQVNDGDTEN=grid%rqvndgdten,RMUNDGDTEN=grid%rmundgdten,            &
846                   u_ndg_old=fdda3d(ims,kms,jms,P_u_ndg_old),                        &
847                   v_ndg_old=fdda3d(ims,kms,jms,P_v_ndg_old),                        &
848                   t_ndg_old=fdda3d(ims,kms,jms,P_t_ndg_old),                        &
849                   ph_ndg_old=fdda3d(ims,kms,jms,P_ph_ndg_old),                      &
850                   q_ndg_old=fdda3d(ims,kms,jms,P_q_ndg_old),                        &
851                   mu_ndg_old=fdda2d(ims,1,jms,P_mu_ndg_old),                        &
852                   u_ndg_new=fdda3d(ims,kms,jms,P_u_ndg_new),                        &
853                   v_ndg_new=fdda3d(ims,kms,jms,P_v_ndg_new),                        &
854                   t_ndg_new=fdda3d(ims,kms,jms,P_t_ndg_new),                        &
855                   ph_ndg_new=fdda3d(ims,kms,jms,P_ph_ndg_new),                      &
856                   q_ndg_new=fdda3d(ims,kms,jms,P_q_ndg_new),                        &
857                   mu_ndg_new=fdda2d(ims,1,jms,P_mu_ndg_new),                        &
858                   u3d=grid%u_2,v3d=grid%v_2,th_phy=th_phy,                          &
859                   ph=grid%ph_2,rho=rho,moist=moist,                                 &
860                   p_phy=p_phy,pi_phy=pi_phy,p8w=p8w,t_phy=grid%t_phy,               &
861                   dz8w=dz8w,z=grid%z,z_at_w=grid%z_at_w,                            &
862                   grid=grid,config_flags=config_flags,dx=grid%DX,n_moist=num_moist, &
863                   STEPFG=grid%STEPFG,                                               &
864                   pblh=grid%pblh,ht=grid%ht,REGIME=grid%regime,ZNT=grid%znt         &
865                    ,IDS=ids,IDE=ide, JDS=jds,JDE=jde, KDS=kds,KDE=kde               &
866                    ,IMS=ims,IME=ime, JMS=jms,JME=jme, KMS=kms,KME=kme               &
867                    ,I_START=grid%i_start,I_END=min(grid%i_end, ide-1)               &
868                    ,J_START=grid%j_start,J_END=min(grid%j_end, jde-1)               &
869                    ,KTS=k_start, KTE=min(k_end,kde-1)                               &
870                    , num_tiles=grid%num_tiles,                                      &
871                    u10=grid%u10, v10=grid%v10, th2=grid%th2, q2=grid%q2,            &
872                    u10_ndg_old=grid%u10_ndg_old,                    &
873                    v10_ndg_old=grid%v10_ndg_old,                    &
874                    t2_ndg_old=grid%t2_ndg_old,                      &
875                    th2_ndg_old=grid%th2_ndg_old,                    &
876                    q2_ndg_old=grid%q2_ndg_old,                      &
877                    rh_ndg_old=grid%rh_ndg_old,                      &
878                    psl_ndg_old=grid%psl_ndg_old,                    &
879                    ps_ndg_old=grid%ps_ndg_old,                      &
880                    tob_ndg_old=grid%tob_ndg_old,                                    &
881                    odis_ndg_old=grid%odis_ndg_old,                                  &
882                    u10_ndg_new=grid%u10_ndg_new,                    &
883                    v10_ndg_new=grid%v10_ndg_new,                    &
884                    t2_ndg_new=grid%t2_ndg_new,                      &
885                    th2_ndg_new=grid%th2_ndg_new,                    &
886                    q2_ndg_new=grid%q2_ndg_new,                      &
887                    rh_ndg_new=grid%rh_ndg_new,                      &
888                    psl_ndg_new=grid%psl_ndg_new,                    &
889                    ps_ndg_new=grid%ps_ndg_new,                      &
890                    tob_ndg_new=grid%tob_ndg_new,                                    &
891                    odis_ndg_new=grid%odis_ndg_new                                   &
892                    ,IPS=ips,IPE=ipe, JPS=jps,JPE=jpe, KPS=kps,KPE=kpe               &
893                    ,IMSX=imsx,IMEX=imex,JMSX=jmsx,JMEX=jmex,KMSX=kmsx,KMEX=kmex     &
894                    ,IPSX=ipsx,IPEX=ipex,JPSX=jpsx,JPEX=jpex,KPSX=kpsx,KPEX=kpex     &
895                    ,IMSY=imsy,IMEY=imey,JMSY=jmsy,JMEY=jmey,KMSY=kmsy,KMEY=kmey     &
896                    ,IPSY=ipsy,IPEY=ipey,JPSY=jpsy,JPEY=jpey,KPSY=kpsy,KPEY=kpey     )
898 BENCH_END(fdda_driver_tim)
900   END SUBROUTINE first_rk_step_part1
902 END MODULE module_first_rk_step_part1