Changeset 318


Ignore:
Timestamp:
May 15, 2009 4:25:33 PM (16 years ago)
Author:
letzel
Message:
  • Modified timestep criterion in case of simulations with plant canopy (timestep; modules rolled back to revision 305)
Location:
palm/trunk/SOURCE
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • palm/trunk/SOURCE/CURRENT_MODIFICATIONS

    r316 r318  
    11New:
    22---
    3 Additional timestep criterion in case of simulations with plant canopy (modules, timestep)
     3Additional timestep criterion in case of simulations with plant canopy (timestep)
    44
    55Check for illegal entries in section_xy|xz|yz that exceed nz+1|ny+1|nx+1
  • palm/trunk/SOURCE/modules.f90

    r316 r318  
    55! Actual revisions:
    66! -----------------
    7 ! +cdc_max, lad_u_max, lad_v_max, lad_w_max,
    8 ! cdc_max_ijk, lad_u_max_ijk, lad_v_max_ijk, lad_w_max_ijk
    97! typographical error in dots_unit fixed
    108! +clip_dvrp_*, cluster_size, color_interval, dvrpsize_interval, dvrp_overlap,
     
    12191217    CHARACTER (LEN=40) ::  region(0:9)
    12201218    INTEGER ::  pr_palm = 80, statistic_regions = 0, var_ts = 100
    1221     INTEGER ::  cdc_max_ijk(3), lad_u_max_ijk(3), lad_v_max_ijk(3),  &
    1222                 lad_w_max_ijk(3), u_max_ijk(3), v_max_ijk(3), w_max_ijk(3)
     1219    INTEGER ::  u_max_ijk(3), v_max_ijk(3), w_max_ijk(3)
    12231220    LOGICAL ::  flow_statistics_called = .FALSE.
    1224     REAL ::     cdc_max, lad_u_max, lad_v_max, lad_w_max, u_max, v_max, w_max
     1221    REAL ::     u_max, v_max, w_max
    12251222    REAL, DIMENSION(:), ALLOCATABLE       ::  sums_divnew_l, sums_divold_l
    12261223    REAL, DIMENSION(:,:), ALLOCATABLE     ::  sums, sums_wsts_bc_l, ts_value
  • palm/trunk/SOURCE/timestep.f90

    r316 r318  
    4747    INTEGER ::  i, j, k
    4848
    49     REAL ::  div, dt_diff, dt_diff_l, dt_plant_canopy,  &
    50              dt_u, dt_v, dt_w, lad_max, percent_change, &
     49    REAL ::  div, dt_diff, dt_diff_l, dt_plant_canopy,                 &
     50             dt_plant_canopy_l,                                        &
     51             dt_plant_canopy_u, dt_plant_canopy_v, dt_plant_canopy_w,  &
     52             dt_u, dt_v, dt_w, lad_max, percent_change,                &
    5153             u_gtrans_l, vabs_max, value, v_gtrans_l
    5254
     
    182184!--    it is not allowed to extract more than the available momentum
    183185       IF ( plant_canopy ) THEN
    184 !
    185 !--       Determine the maxima of the leaf drag coefficient and the leaf
    186 !--       area density.
    187           CALL global_min_max( nzb, nzt+1, nys-1, nyn+1, nxl-1, nxr+1, cdc, &
    188                                'max', cdc_max, cdc_max_ijk )
    189           CALL global_min_max( nzb, nzt+1, nys-1, nyn+1, nxl-1, nxr+1, lad_u, &
    190                                'max', lad_u_max, lad_u_max_ijk )
    191           CALL global_min_max( nzb, nzt+1, nys-1, nyn+1, nxl-1, nxr+1, lad_v, &
    192                                'max', lad_v_max, lad_v_max_ijk )
    193           CALL global_min_max( nzb, nzt+1, nys-1, nyn+1, nxl-1, nxr+1, lad_w, &
    194                                'max', lad_w_max, lad_w_max_ijk )
    195 !
    196 !--       Determine the potential maximum of the absolute value of the velocity
    197           vabs_max = SQRT( u_max**2 + v_max**2 + w_max**2 )
    198           lad_max  = MAX( lad_u_max, lad_v_max, lad_w_max )
    199 
    200           dt_plant_canopy = 1.0 / ( cdc_max * lad_max * vabs_max )
     186
     187          dt_plant_canopy_l = 0.0
     188          DO  i = nxl, nxr
     189             DO  j = nys, nyn
     190                DO k = nzb+1, nzt
     191                   dt_plant_canopy_u = cdc(k,j,i) * lad_u(k,j,i) *  &
     192                                       SQRT(     u(k,j,i)**2     +  &
     193                                             ( ( v(k,j,i-1)      +  &
     194                                                 v(k,j,i)        +  &
     195                                                 v(k,j+1,i)      +  &
     196                                                 v(k,j+1,i-1) )     &
     197                                               / 4.0 )**2        +  &
     198                                             ( ( w(k-1,j,i-1)    +  &
     199                                                 w(k-1,j,i)      +  &
     200                                                 w(k,j,i-1)      +  &
     201                                                 w(k,j,i) )         &
     202                                                 / 4.0 )**2 )
     203                   IF ( dt_plant_canopy_u > dt_plant_canopy_l ) THEN
     204                      dt_plant_canopy_l = dt_plant_canopy_u 
     205                   ENDIF
     206                   dt_plant_canopy_v = cdc(k,j,i) * lad_v(k,j,i) *  &
     207                                       SQRT( ( ( u(k,j-1,i)      +  &
     208                                                 u(k,j-1,i+1)    +  &
     209                                                 u(k,j,i)        +  &
     210                                                 u(k,j,i+1) )       &
     211                                               / 4.0 )**2        +  &
     212                                                 v(k,j,i)**2     +  &
     213                                             ( ( w(k-1,j-1,i)    +  &
     214                                                 w(k-1,j,i)      +  &
     215                                                 w(k,j-1,i)      +  &
     216                                                 w(k,j,i) )         &
     217                                                 / 4.0 )**2 )
     218                   IF ( dt_plant_canopy_v > dt_plant_canopy_l ) THEN
     219                      dt_plant_canopy_l = dt_plant_canopy_v
     220                   ENDIF                   
     221                   dt_plant_canopy_w = cdc(k,j,i) * lad_w(k,j,i) *  &
     222                                       SQRT( ( ( u(k,j,i)        +  &
     223                                                 u(k,j,i+1)      +  &
     224                                                 u(k+1,j,i)      +  &
     225                                                 u(k+1,j,i+1) )     &
     226                                               / 4.0 )**2        +  &
     227                                             ( ( v(k,j,i)        +  &
     228                                                 v(k,j+1,i)      +  &
     229                                                 v(k+1,j,i)      +  &
     230                                                 v(k+1,j+1,i) )     &
     231                                               / 4.0 )**2        +  &
     232                                                 w(k,j,i)**2 )     
     233                   IF ( dt_plant_canopy_w > dt_plant_canopy_l ) THEN
     234                      dt_plant_canopy_l = dt_plant_canopy_w
     235                   ENDIF
     236                ENDDO
     237             ENDDO
     238          ENDDO
     239
     240          IF ( dt_plant_canopy_l > 0.0 ) THEN
     241             dt_plant_canopy_l = 0.1 / dt_plant_canopy_l
     242          ENDIF
     243!
     244!--       Determine the global minumum
     245#if defined( __parallel )
     246          CALL MPI_ALLREDUCE( dt_plant_canopy_l, dt_plant_canopy, 1, MPI_REAL,  &
     247                              MPI_MIN, comm2d, ierr )
     248#else
     249          dt_plant_canopy = dt_plant_canopy_l
     250#endif
    201251
    202252       ELSE
Note: See TracChangeset for help on using the changeset viewer.