Changeset 4517


Ignore:
Timestamp:
May 3, 2020 2:29:30 PM (4 years ago)
Author:
raasch
Message:

added restart with MPI-IO for reading local arrays

Location:
palm/trunk/SOURCE
Files:
18 edited

Legend:

Unmodified
Added
Removed
  • palm/trunk/SOURCE/Makefile

    r4513 r4517  
    2525# -----------------
    2626# $Id$
     27# dependencies for MPI-IO added
     28#
     29# 4513 2020-04-30 13:45:47Z raasch
    2730# dependencies from chemistry modules updated
    2831#
     
    460463        palm_date_time_mod.o \
    461464        radiation_model_mod.o \
     465        restart_data_mpi_io_mod.o \
    462466        surface_mod.o
    463467chem_gasphase_mod.o: \
  • palm/trunk/SOURCE/biometeorology_mod.f90

    r4495 r4517  
    2727! -----------------
    2828! $Id$
     29! added restart with MPI-IO for reading local arrays
     30!
     31! 4495 2020-04-13 20:11:20Z raasch
    2932! restart data handling with MPI-IO added
    3033!
     
    365368!-- Read local restart parameters
    366369    INTERFACE bio_rrd_local
    367        MODULE PROCEDURE bio_rrd_local
     370       MODULE PROCEDURE bio_rrd_local_ftn
     371       MODULE PROCEDURE bio_rrd_local_mpi
    368372    END INTERFACE bio_rrd_local
    369373!
     
    14291433! Description:
    14301434! ------------
    1431 !> Soubroutine reads local biometeorology configuration from restart file(s)
    1432 !------------------------------------------------------------------------------!
    1433  SUBROUTINE bio_rrd_local( found )
     1435!> Read module-specific local restart data arrays (Fortran binary format).
     1436!------------------------------------------------------------------------------!
     1437 SUBROUTINE bio_rrd_local_ftn( found )
    14341438
    14351439
     
    14651469
    14661470
    1467  END SUBROUTINE bio_rrd_local
     1471 END SUBROUTINE bio_rrd_local_ftn
     1472
     1473
     1474!------------------------------------------------------------------------------!
     1475! Description:
     1476! ------------
     1477!> Read module-specific local restart data arrays (Fortran binary format).
     1478!------------------------------------------------------------------------------!
     1479 SUBROUTINE bio_rrd_local_mpi
     1480
     1481    STOP '+++ reading restart data with MPI-IO not implemented for bio_rrd_local_mpi'
     1482
     1483 END SUBROUTINE bio_rrd_local_mpi
     1484
    14681485
    14691486!------------------------------------------------------------------------------!
  • palm/trunk/SOURCE/bulk_cloud_model_mod.f90

    r4506 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4506 2020-04-21 10:57:45Z schwenkel
    2730! Use correct magnus formula for liquid water temperature
    2831!
     
    183186
    184187    USE restart_data_mpi_io_mod,                                               &
    185         ONLY:  rrd_mpi_io, wrd_mpi_io
     188        ONLY:  rd_mpi_io_check_array, rrd_mpi_io, wrd_mpi_io
    186189
    187190    USE statistics,                                                            &
     
    404407
    405408    INTERFACE bcm_rrd_local
    406        MODULE PROCEDURE bcm_rrd_local
     409       MODULE PROCEDURE bcm_rrd_local_ftn
     410       MODULE PROCEDURE bcm_rrd_local_mpi
    407411    END INTERFACE bcm_rrd_local
    408412
     
    33973401! Description:
    33983402! ------------
    3399 !> This routine reads the respective restart data for the bulk cloud module.
    3400 !------------------------------------------------------------------------------!
    3401     SUBROUTINE bcm_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
    3402                               nxr_on_file, nynf, nync, nyn_on_file, nysf,      &
    3403                               nysc, nys_on_file, tmp_2d, tmp_3d, found )
     3403!> Read module-specific local restart data arrays (Fortran binary format).
     3404!------------------------------------------------------------------------------!
     3405    SUBROUTINE bcm_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
     3406                                  nxr_on_file, nynf, nync, nyn_on_file, nysf,      &
     3407                                  nysc, nys_on_file, tmp_2d, tmp_3d, found )
    34043408
    34053409
     
    34323436       REAL(wp), DIMENSION(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,nxl_on_file-nbgp:nxr_on_file+nbgp) :: tmp_3d   !<
    34333437
    3434 !
    3435 !-- Here the reading of user-defined restart data follows:
    3436 !-- Sample for user-defined output
    3437 
    34383438
    34393439       found = .TRUE.
     
    35613561
    35623562
    3563     END SUBROUTINE bcm_rrd_local
     3563    END SUBROUTINE bcm_rrd_local_ftn
     3564
     3565
     3566!------------------------------------------------------------------------------!
     3567! Description:
     3568! ------------
     3569!> Read module-specific local restart data arrays (MPI-IO).
     3570!------------------------------------------------------------------------------!
     3571    SUBROUTINE bcm_rrd_local_mpi
     3572
     3573       LOGICAL ::  array_found  !<
     3574
     3575
     3576       CALL rd_mpi_io_check_array( 'prr' , found = array_found )
     3577       IF ( array_found )  THEN
     3578          IF ( .NOT. ALLOCATED( prr ) )  ALLOCATE( prr(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3579          CALL rrd_mpi_io( 'prr', prr )
     3580       ENDIF
     3581
     3582       CALL rd_mpi_io_check_array( 'prr_av' , found = array_found )
     3583       IF ( array_found )  THEN
     3584          IF ( .NOT. ALLOCATED( prr_av ) )  ALLOCATE( prr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3585          CALL rrd_mpi_io( 'prr_av', prr_av )
     3586       ENDIF
     3587
     3588       CALL rd_mpi_io_check_array( 'precipitation_amount' , found = array_found )
     3589       IF ( array_found )  THEN
     3590          IF ( .NOT. ALLOCATED( precipitation_amount ) )  THEN
     3591             ALLOCATE( precipitation_amount(nysg:nyng,nxlg:nxrg) )
     3592          ENDIF
     3593          CALL rrd_mpi_io( 'precipitation_amount', precipitation_amount )
     3594       ENDIF
     3595
     3596       CALL rrd_mpi_io( 'ql', ql )
     3597
     3598       CALL rd_mpi_io_check_array( 'ql_av' , found = array_found )
     3599       IF ( array_found )  THEN
     3600          IF ( .NOT. ALLOCATED( ql_av ) )  ALLOCATE( ql_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3601          CALL rrd_mpi_io( 'ql_av', ql_av )
     3602       ENDIF
     3603
     3604       CALL rrd_mpi_io( 'qc', qc )
     3605
     3606       CALL rd_mpi_io_check_array( 'qc_av' , found = array_found )
     3607       IF ( array_found )  THEN
     3608          IF ( .NOT. ALLOCATED( qc_av ) )  ALLOCATE( qc_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3609          CALL rrd_mpi_io( 'qc_av', qc_av )
     3610       ENDIF
     3611
     3612       IF ( microphysics_morrison )  THEN
     3613
     3614          CALL rrd_mpi_io( 'nc', nc )
     3615
     3616          CALL rd_mpi_io_check_array( 'nc_av' , found = array_found )
     3617          IF ( array_found )  THEN
     3618             IF ( .NOT. ALLOCATED( nc_av ) )  ALLOCATE( nc_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3619             CALL rrd_mpi_io( 'nc_av', nc_av )
     3620          ENDIF
     3621
     3622       ENDIF
     3623
     3624       IF ( microphysics_seifert )  THEN
     3625
     3626          CALL rrd_mpi_io( 'nr', nr )
     3627
     3628          CALL rd_mpi_io_check_array( 'nr_av' , found = array_found )
     3629          IF ( array_found )  THEN
     3630             IF ( .NOT. ALLOCATED( nr_av ) )  ALLOCATE( nr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3631             CALL rrd_mpi_io( 'nr_av', nr_av )
     3632          ENDIF
     3633
     3634          CALL rrd_mpi_io( 'qr', qr )
     3635
     3636          CALL rd_mpi_io_check_array( 'qr_av' , found = array_found )
     3637          IF ( array_found )  THEN
     3638             IF ( .NOT. ALLOCATED( qr_av ) )  ALLOCATE( qr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3639             CALL rrd_mpi_io( 'qr_av', qr_av )
     3640          ENDIF
     3641
     3642       ENDIF
     3643
     3644       IF ( microphysics_ice_extension )  THEN
     3645
     3646          CALL rrd_mpi_io( 'ni', ni )
     3647
     3648          CALL rd_mpi_io_check_array( 'ni_av' , found = array_found )
     3649          IF ( array_found )  THEN
     3650             IF ( .NOT. ALLOCATED( ni_av ) )  ALLOCATE( ni_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3651             CALL rrd_mpi_io( 'ni_av', ni_av )
     3652          ENDIF
     3653
     3654          CALL rrd_mpi_io( 'qi', qi )
     3655
     3656          CALL rd_mpi_io_check_array( 'qi_av' , found = array_found )
     3657          IF ( array_found )  THEN
     3658             IF ( .NOT. ALLOCATED( qi_av ) )  ALLOCATE( qi_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3659             CALL rrd_mpi_io( 'qi_av', qi_av )
     3660          ENDIF
     3661
     3662       ENDIF
     3663
     3664
     3665    END SUBROUTINE bcm_rrd_local_mpi
    35643666
    35653667
  • palm/trunk/SOURCE/chemistry_model_mod.f90

    r4511 r4517  
    2727! -----------------
    2828! $Id$
     29! added restart with MPI-IO
     30!
     31! 4511 2020-04-30 12:20:40Z raasch
    2932! decycling replaced by explicit setting of lateral boundary conditions
    3033!
     
    312315                max_pr_user,                                                                       &
    313316                monotonic_limiter_z,                                                               &
     317                restart_data_format_output,                                                        &
    314318                scalar_advec,                                                                      &
    315319                timestep_scheme, use_prescribed_profile_data, ws_scheme_sca, air_chemistry
     
    329333    USE cpulog,                                                                                    &
    330334        ONLY:  cpu_log, log_point_s
     335
     336    USE restart_data_mpi_io_mod,                                                                   &
     337        ONLY:  rrd_mpi_io, wrd_mpi_io
    331338
    332339    USE statistics
     
    501508
    502509    INTERFACE chem_rrd_local
    503        MODULE PROCEDURE chem_rrd_local
     510       MODULE PROCEDURE chem_rrd_local_ftn
     511       MODULE PROCEDURE chem_rrd_local_mpi
    504512    END INTERFACE chem_rrd_local
    505513
     
    30423050! Description:
    30433051! ------------
    3044 !> Subroutine to read restart data of chemical species
    3045 !------------------------------------------------------------------------------!
    3046  SUBROUTINE chem_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,             &
    3047                             nxr_on_file, nynf, nync, nyn_on_file, nysf, nysc,   &
    3048                             nys_on_file, tmp_3d, found )
     3052!> Read module-specific local restart data arrays (Fortran binary format).
     3053!------------------------------------------------------------------------------!
     3054 SUBROUTINE chem_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,             &
     3055                                nxr_on_file, nynf, nync, nyn_on_file, nysf, nysc,   &
     3056                                nys_on_file, tmp_3d, found )
    30493057
    30503058    USE control_parameters
     
    30763084
    30773085
    3078     IF ( ALLOCATED(chem_species) )  THEN
     3086    IF ( ALLOCATED( chem_species ) )  THEN
    30793087
    30803088       DO  lsp = 1, nspec
     
    31053113
    31063114
    3107  END SUBROUTINE chem_rrd_local
     3115 END SUBROUTINE chem_rrd_local_ftn
     3116
     3117
     3118!------------------------------------------------------------------------------!
     3119! Description:
     3120! ------------
     3121!> Read module-specific local restart data arrays (Fortran binary format).
     3122!------------------------------------------------------------------------------!
     3123 SUBROUTINE chem_rrd_local_mpi
     3124
     3125    IMPLICIT NONE
     3126
     3127    INTEGER(iwp) ::  lsp !<
     3128
     3129    IF ( ALLOCATED( chem_species ) )  THEN
     3130
     3131       DO  lsp = 1, nspec
     3132
     3133          CALL rrd_mpi_io( TRIM( chem_species(lsp)%name ), chem_species(lsp)%conc )
     3134          CALL rrd_mpi_io( TRIM( chem_species(lsp)%name )//'_av', chem_species(lsp)%conc_av )
     3135
     3136       ENDDO
     3137
     3138    ENDIF
     3139
     3140 END SUBROUTINE chem_rrd_local_mpi
    31083141
    31093142
     
    32083241    INTEGER(iwp) ::  lsp  !< running index for chem spcs.
    32093242
    3210     DO  lsp = 1, nspec
    3211        CALL wrd_write_string( TRIM( chem_species(lsp)%name ) )
    3212        WRITE ( 14 )  chem_species(lsp)%conc
    3213        CALL wrd_write_string( TRIM( chem_species(lsp)%name )//'_av' )
    3214        WRITE ( 14 )  chem_species(lsp)%conc_av
    3215     ENDDO
     3243    IF ( TRIM( restart_data_format_output ) == 'fortran_binary' )  THEN
     3244
     3245       DO  lsp = 1, nspec
     3246          CALL wrd_write_string( TRIM( chem_species(lsp)%name ) )
     3247          WRITE ( 14 )  chem_species(lsp)%conc
     3248          CALL wrd_write_string( TRIM( chem_species(lsp)%name )//'_av' )
     3249          WRITE ( 14 )  chem_species(lsp)%conc_av
     3250       ENDDO
     3251
     3252    ELSEIF ( TRIM( restart_data_format_output ) == 'mpi' )  THEN
     3253
     3254       DO  lsp = 1, nspec
     3255          CALL wrd_mpi_io( TRIM( chem_species(lsp)%name ), chem_species(lsp)%conc )
     3256          CALL wrd_mpi_io( TRIM( chem_species(lsp)%name ) // '_av', chem_species(lsp)%conc_av )
     3257       ENDDO
     3258
     3259    ENDIF
    32163260
    32173261 END SUBROUTINE chem_wrd_local
  • palm/trunk/SOURCE/diagnostic_output_quantities_mod.f90

    r4457 r4517  
    110110               data_output,                                                    &
    111111               message_string,                                                 &
     112               restart_data_format_output,                                     &
    112113               varnamelength
    113114!
     
    19421943!> Note: With the current structure reading of non-standard array is not
    19431944!> possible
     1945!> COMMENT:  these arrays should be given standard index bounds! (Siggi)
    19441946!------------------------------------------------------------------------------!
    19451947!  SUBROUTINE doq_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,             &
     
    20482050    IMPLICIT NONE
    20492051
    2050     IF ( ALLOCATED( pt_2m_av ) )  THEN
    2051        CALL wrd_write_string( 'pt_2m_av' )
    2052        WRITE ( 14 )  pt_2m_av
     2052    IF ( TRIM( restart_data_format_output ) == 'fortran_binary' )  THEN
     2053
     2054       IF ( ALLOCATED( pt_2m_av ) )  THEN
     2055          CALL wrd_write_string( 'pt_2m_av' )
     2056          WRITE ( 14 )  pt_2m_av
     2057       ENDIF
     2058
     2059       IF ( ALLOCATED( ti_av ) )  THEN
     2060          CALL wrd_write_string( 'ti_av' )
     2061          WRITE ( 14 )  ti_av
     2062       ENDIF
     2063
     2064       IF ( ALLOCATED( uu_av ) )  THEN
     2065          CALL wrd_write_string( 'uu_av' )
     2066          WRITE ( 14 )  uu_av
     2067       ENDIF
     2068
     2069       IF ( ALLOCATED( uv_10m_av ) )  THEN
     2070          CALL wrd_write_string( 'uv_10m_av' )
     2071          WRITE ( 14 )  uv_10m_av
     2072       ENDIF
     2073
     2074       IF ( ALLOCATED( vv_av ) )  THEN
     2075          CALL wrd_write_string( 'vv_av' )
     2076          WRITE ( 14 )  vv_av
     2077       ENDIF
     2078
     2079       IF ( ALLOCATED( ww_av ) )  THEN
     2080          CALL wrd_write_string( 'ww_av' )
     2081          WRITE ( 14 )  ww_av
     2082       ENDIF
     2083
     2084       IF ( ALLOCATED( wu_av ) )  THEN
     2085          CALL wrd_write_string( 'wu_av' )
     2086          WRITE ( 14 )  wu_av
     2087       ENDIF
     2088
     2089       IF ( ALLOCATED( wv_av ) )  THEN
     2090          CALL wrd_write_string( 'wv_av' )
     2091          WRITE ( 14 )  wv_av
     2092       ENDIF
     2093
     2094       IF ( ALLOCATED( wtheta_av ) )  THEN
     2095          CALL wrd_write_string( 'wtheta_av' )
     2096          WRITE ( 14 )  wtheta_av
     2097       ENDIF
     2098
     2099       IF ( ALLOCATED( wq_av ) )  THEN
     2100          CALL wrd_write_string( 'wq_av' )
     2101          WRITE ( 14 )  wq_av
     2102       ENDIF
     2103
     2104       IF ( ALLOCATED( wspeed_av ) )  THEN
     2105          CALL wrd_write_string( 'wspeed_av' )
     2106          WRITE ( 14 )  wspeed_av
     2107       ENDIF
     2108
     2109       IF ( ALLOCATED( u_center_av ) )  THEN
     2110          CALL wrd_write_string( 'u_center_av' )
     2111          WRITE ( 14 )  u_center_av
     2112       ENDIF
     2113
     2114       IF ( ALLOCATED( v_center_av ) )  THEN
     2115          CALL wrd_write_string( 'v_center_av' )
     2116          WRITE ( 14 )  v_center_av
     2117       ENDIF
     2118
     2119    ELSEIF ( TRIM( restart_data_format_output ) == 'mpi' )  THEN
     2120
     2121       STOP 'mpi-io for doq_wrd_local not realized'
     2122
    20532123    ENDIF
    20542124
    2055     IF ( ALLOCATED( ti_av ) )  THEN
    2056        CALL wrd_write_string( 'ti_av' )
    2057        WRITE ( 14 )  ti_av
    2058     ENDIF
    2059 
    2060     IF ( ALLOCATED( uu_av ) )  THEN
    2061        CALL wrd_write_string( 'uu_av' )
    2062        WRITE ( 14 )  uu_av
    2063     ENDIF
    2064 
    2065     IF ( ALLOCATED( uv_10m_av ) )  THEN
    2066        CALL wrd_write_string( 'uv_10m_av' )
    2067        WRITE ( 14 )  uv_10m_av
    2068     ENDIF
    2069 
    2070     IF ( ALLOCATED( vv_av ) )  THEN
    2071        CALL wrd_write_string( 'vv_av' )
    2072        WRITE ( 14 )  vv_av
    2073     ENDIF
    2074 
    2075     IF ( ALLOCATED( ww_av ) )  THEN
    2076        CALL wrd_write_string( 'ww_av' )
    2077        WRITE ( 14 )  ww_av
    2078     ENDIF
    2079 
    2080     IF ( ALLOCATED( wu_av ) )  THEN
    2081        CALL wrd_write_string( 'wu_av' )
    2082        WRITE ( 14 )  wu_av
    2083     ENDIF
    2084 
    2085     IF ( ALLOCATED( wv_av ) )  THEN
    2086        CALL wrd_write_string( 'wv_av' )
    2087        WRITE ( 14 )  wv_av
    2088     ENDIF
    2089 
    2090     IF ( ALLOCATED( wtheta_av ) )  THEN
    2091        CALL wrd_write_string( 'wtheta_av' )
    2092        WRITE ( 14 )  wtheta_av
    2093     ENDIF
    2094 
    2095     IF ( ALLOCATED( wq_av ) )  THEN
    2096        CALL wrd_write_string( 'wq_av' )
    2097        WRITE ( 14 )  wq_av
    2098     ENDIF
    2099 
    2100     IF ( ALLOCATED( wspeed_av ) )  THEN
    2101        CALL wrd_write_string( 'wspeed_av' )
    2102        WRITE ( 14 )  wspeed_av
    2103     ENDIF
    2104 
    2105     IF ( ALLOCATED( u_center_av ) )  THEN
    2106        CALL wrd_write_string( 'u_center_av' )
    2107        WRITE ( 14 )  u_center_av
    2108     ENDIF
    2109 
    2110     IF ( ALLOCATED( v_center_av ) )  THEN
    2111        CALL wrd_write_string( 'v_center_av' )
    2112        WRITE ( 14 )  v_center_av
    2113     ENDIF
    2114 
    21152125 END SUBROUTINE doq_wrd_local
    21162126
  • palm/trunk/SOURCE/dynamics_mod.f90

    r4505 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4505 2020-04-20 15:37:15Z schwenkel
    2730! Add flag for saturation check
    2831!
     
    279282
    280283    INTERFACE dynamics_rrd_local
    281        MODULE PROCEDURE dynamics_rrd_local
     284       MODULE PROCEDURE dynamics_rrd_local_ftn
     285       MODULE PROCEDURE dynamics_rrd_local_mpi
    282286    END INTERFACE dynamics_rrd_local
    283287
     
    18711875! Description:
    18721876! ------------
    1873 !> Read module-specific processor specific restart data from file(s).
     1877!> Read module-specific local restart data arrays (Fortran binary format).
    18741878!> Subdomain index limits on file are given by nxl_on_file, etc.
    18751879!> Indices nxlc, etc. indicate the range of gridpoints to be mapped from the subdomain on file (f)
    18761880!> to the subdomain of the current PE (c). They have been calculated in routine rrd_local.
    18771881!--------------------------------------------------------------------------------------------------!
    1878  SUBROUTINE dynamics_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc, nxr_on_file, nynf, nync,   &
    1879                                 nyn_on_file, nysf, nysc, nys_on_file, tmp_2d, tmp_3d, found )
     1882 SUBROUTINE dynamics_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc, nxr_on_file, nynf, nync,   &
     1883                                    nyn_on_file, nysf, nysc, nys_on_file, tmp_2d, tmp_3d, found )
    18801884
    18811885
     
    19201924    END SELECT
    19211925
    1922  END SUBROUTINE dynamics_rrd_local
     1926 END SUBROUTINE dynamics_rrd_local_ftn
     1927
     1928
     1929!--------------------------------------------------------------------------------------------------!
     1930! Description:
     1931! ------------
     1932!> Read module-specific local restart data arrays (MPI-IO).
     1933!--------------------------------------------------------------------------------------------------!
     1934 SUBROUTINE dynamics_rrd_local_mpi
     1935
     1936    IMPLICIT NONE
     1937
     1938!    LOGICAL ::  array_found  !<
     1939
     1940
     1941!    CALL rd_mpi_io_check_array( 'u2_av' , found = array_found )
     1942!    IF ( array_found )  THEN
     1943!       IF ( .NOT. ALLOCATED( u2_av ) )  ALLOCATE( u2_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1944!       CALL rrd_mpi_io( 'u2_av', u2_av )
     1945!    ENDIF
     1946
     1947    CONTINUE
     1948
     1949 END SUBROUTINE dynamics_rrd_local_mpi
     1950
    19231951
    19241952
  • palm/trunk/SOURCE/gust_mod.f90

    r4495 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4495 2020-04-13 20:11:20Z raasch
    2730! restart data handling with MPI-IO added
    2831!
     
    186189
    187190    INTERFACE gust_rrd_local
    188        MODULE PROCEDURE gust_rrd_local
     191       MODULE PROCEDURE gust_rrd_local_ftn
     192       MODULE PROCEDURE gust_rrd_local_mpi
    189193    END INTERFACE gust_rrd_local
    190194
     
    618622! Description:
    619623! ------------
    620 !> This routine reads the respective restart data for the gust module.
    621 !------------------------------------------------------------------------------!
    622     SUBROUTINE gust_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,         &
    623                                nxr_on_file, nynf, nync, nyn_on_file, nysf,     &
    624                                nysc, nys_on_file, tmp_2d, tmp_3d, found )
     624!> Read module-specific local restart data arrays (Fortran binary format).
     625!------------------------------------------------------------------------------!
     626    SUBROUTINE gust_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,         &
     627                                   nxr_on_file, nynf, nync, nyn_on_file, nysf,     &
     628                                   nysc, nys_on_file, tmp_2d, tmp_3d, found )
    625629
    626630
     
    686690
    687691
    688     END SUBROUTINE gust_rrd_local
     692    END SUBROUTINE gust_rrd_local_ftn
     693
     694
     695!------------------------------------------------------------------------------!
     696! Description:
     697! ------------
     698!> Read module-specific local restart data arrays (MPI-IO).
     699!------------------------------------------------------------------------------!
     700    SUBROUTINE gust_rrd_local_mpi
     701
     702
     703!       CALL rrd_mpi_io( 'local_array', local_array )
     704
     705    END SUBROUTINE gust_rrd_local_mpi
    689706
    690707
  • palm/trunk/SOURCE/lagrangian_particle_model_mod.f90

    r4495 r4517  
    210210
    211211    USE restart_data_mpi_io_mod,                                                                   &
    212         ONLY:  rrd_mpi_io, wrd_mpi_io
     212        ONLY:  rd_mpi_io_check_array, rrd_mpi_io, wrd_mpi_io
    213213
    214214    USE statistics,                                                            &
     
    413413
    414414    INTERFACE lpm_rrd_local
    415        MODULE PROCEDURE lpm_rrd_local
     415       MODULE PROCEDURE lpm_rrd_local_ftn
     416       MODULE PROCEDURE lpm_rrd_local_mpi
    416417    END INTERFACE lpm_rrd_local
    417418
     
    30213022 
    30223023 
    3023  SUBROUTINE lpm_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
    3024                               nxr_on_file, nynf, nync, nyn_on_file, nysf,  &
    3025                               nysc, nys_on_file, tmp_3d, found )
     3024!------------------------------------------------------------------------------!
     3025! Description:
     3026! ------------
     3027!> Read module-specific local restart data arrays (Fortran binary format).
     3028!------------------------------------------------------------------------------!
     3029 SUBROUTINE lpm_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
     3030                               nxr_on_file, nynf, nync, nyn_on_file, nysf,  &
     3031                               nysc, nys_on_file, tmp_3d, found )
    30263032
    30273033
     
    31013107       END SELECT
    31023108
    3103 
    3104  END SUBROUTINE lpm_rrd_local
     3109 END SUBROUTINE lpm_rrd_local_ftn
     3110
    31053111 
     3112!------------------------------------------------------------------------------!
     3113! Description:
     3114! ------------
     3115!> Read module-specific local restart data arrays (MPI-IO).
     3116!------------------------------------------------------------------------------!
     3117 SUBROUTINE lpm_rrd_local_mpi
     3118
     3119    IMPLICIT NONE
     3120
     3121    LOGICAL ::  array_found  !<
     3122
     3123    CALL rrd_mpi_io( 'iran', iran ) ! matching random numbers is still unresolved issue
     3124    CALL rrd_mpi_io( 'iran_part', iran_part )
     3125
     3126    CALL rd_mpi_io_check_array( 'pc_av' , found = array_found )
     3127    IF ( array_found )  THEN
     3128       IF ( .NOT. ALLOCATED( pc_av ) )  ALLOCATE( pc_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3129       CALL rrd_mpi_io( 'pc_av', pc_av )
     3130    ENDIF
     3131
     3132    CALL rd_mpi_io_check_array( 'pr_av' , found = array_found )
     3133    IF ( array_found )  THEN
     3134       IF ( .NOT. ALLOCATED( pr_av ) )  ALLOCATE( pr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3135       CALL rrd_mpi_io( 'pr_av', pr_av )
     3136    ENDIF
     3137
     3138    CALL rd_mpi_io_check_array( 'ql_c_av' , found = array_found )
     3139    IF ( array_found )  THEN
     3140       IF ( .NOT. ALLOCATED( ql_c_av ) )  ALLOCATE( ql_c_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3141       CALL rrd_mpi_io( 'ql_c_av', ql_c_av )
     3142    ENDIF
     3143
     3144    CALL rd_mpi_io_check_array( 'ql_v_av' , found = array_found )
     3145    IF ( array_found )  THEN
     3146       IF ( .NOT. ALLOCATED( ql_v_av ) )  ALLOCATE( ql_v_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3147       CALL rrd_mpi_io( 'ql_v_av', ql_v_av )
     3148    ENDIF
     3149
     3150    CALL rd_mpi_io_check_array( 'ql_vp_av' , found = array_found )
     3151    IF ( array_found )  THEN
     3152       IF ( .NOT. ALLOCATED( ql_vp_av ) )  ALLOCATE( ql_vp_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3153       CALL rrd_mpi_io( 'ql_vp_av', ql_vp_av )
     3154    ENDIF
     3155
     3156 END SUBROUTINE lpm_rrd_local_mpi
     3157
     3158
    31063159!------------------------------------------------------------------------------!
    31073160! Description:
     
    31683221#endif
    31693222
    3170     CALL wrd_write_string( 'iran' )
    3171     WRITE ( 14 )  iran, iran_part
    3172 
     3223    IF ( TRIM( restart_data_format_output ) == 'fortran_binary' )  THEN
     3224
     3225       CALL wrd_write_string( 'iran' )  ! matching random numbers is still unresolved issue
     3226       WRITE ( 14 )  iran, iran_part
     3227
     3228    ELSEIF ( TRIM( restart_data_format_output ) == 'mpi' )  THEN
     3229
     3230       CALL wrd_mpi_io( 'iran', iran )  ! matching random numbers is still unresolved issue
     3231       CALL wrd_mpi_io( 'iran_part', iran_part )
     3232
     3233    ENDIF
    31733234
    31743235 END SUBROUTINE lpm_wrd_local
  • palm/trunk/SOURCE/land_surface_model_mod.f90

    r4495 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4495 2020-04-13 20:11:20Z raasch
    2730! restart data handling with MPI-IO added
    2831!
     
    291294
    292295    USE restart_data_mpi_io_mod,                                                                   &
    293         ONLY:  rd_mpi_io_surface_filetypes, wrd_mpi_io, wrd_mpi_io_surface
     296        ONLY:  rd_mpi_io_check_array, rd_mpi_io_surface_filetypes, rrd_mpi_io, rrd_mpi_io_surface, &
     297               wrd_mpi_io, wrd_mpi_io_surface
    294298
    295299    USE statistics,                                                            &
     
    808812
    809813    INTERFACE lsm_rrd_local
    810        MODULE PROCEDURE lsm_rrd_local
     814       MODULE PROCEDURE lsm_rrd_local_ftn
     815       MODULE PROCEDURE lsm_rrd_local_mpi
    811816    END INTERFACE lsm_rrd_local
    812817
     
    66746679       CALL wrd_mpi_io( 'lsm_end_index_h',  surf_lsm_h%end_index )
    66756680       CALL wrd_mpi_io( 'lsm_global_start_index_h', global_start_index )
    6676        CALL wrd_mpi_io_surface ( 't_soil_h', t_soil_h%var_2d )
     6681       CALL wrd_mpi_io_surface( 't_soil_h', t_soil_h%var_2d )
    66776682       CALL wrd_mpi_io_surface( 'm_soil_h',  m_soil_h%var_2d )
    66786683       CALL wrd_mpi_io_surface( 'm_liq_h', m_liq_h%var_1d )
     
    66866691                                             surface_data_to_write, global_start_index )
    66876692
    6688           CALL wrd_mpi_io( 'lsm_start_index_v_' //dum,  surf_lsm_v(l)%start_index )
    6689           CALL wrd_mpi_io( 'lsm_end_index_v_' //dum,  surf_lsm_v(l)%end_index )
    6690           CALL wrd_mpi_io( 'lsm_global_start_index_v_' //dum , global_start_index )
     6693          CALL wrd_mpi_io( 'lsm_start_index_v_' // dum,  surf_lsm_v(l)%start_index )
     6694          CALL wrd_mpi_io( 'lsm_end_index_v_' // dum,  surf_lsm_v(l)%end_index )
     6695          CALL wrd_mpi_io( 'lsm_global_start_index_v_' // dum , global_start_index )
    66916696
    66926697          IF ( .NOT. surface_data_to_write )  CYCLE
     
    67086713! Description:
    67096714! ------------
    6710 !> Soubroutine reads lsm data from restart file(s)
     6715!> Read module-specific local restart data arrays (Fortran binary format).
    67116716!------------------------------------------------------------------------------!
    6712  SUBROUTINE lsm_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,              &
    6713                           nxr_on_file, nynf, nync, nyn_on_file, nysf, nysc,    &
    6714                           nys_on_file, tmp_2d, found )
     6717 SUBROUTINE lsm_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,              &
     6718                               nxr_on_file, nynf, nync, nyn_on_file, nysf, nysc,    &
     6719                               nys_on_file, tmp_2d, found )
    67156720
    67166721
     
    73057310
    73067311
    7307  END SUBROUTINE lsm_rrd_local
     7312 END SUBROUTINE lsm_rrd_local_ftn
     7313
     7314!------------------------------------------------------------------------------!
     7315!
     7316! Description:
     7317! ------------
     7318!> Read module-specific local restart data arrays (MPI-IO).
     7319!------------------------------------------------------------------------------!
     7320 SUBROUTINE lsm_rrd_local_mpi
     7321
     7322    USE control_parameters
     7323
     7324    USE indices
     7325
     7326    USE pegrid
     7327
     7328
     7329    IMPLICIT NONE
     7330
     7331    CHARACTER(LEN=1) ::  dum  !< dummy to create correct string for creating variable string
     7332
     7333    INTEGER(iwp) ::  l   !< running index surface orientation
     7334
     7335    INTEGER(iwp), DIMENSION(nys:nyn,nxl:nxr) ::  end_index
     7336    INTEGER(iwp), DIMENSION(nys:nyn,nxl:nxr) ::  global_start
     7337    INTEGER(iwp), DIMENSION(nys:nyn,nxl:nxr) ::  start_index
     7338
     7339    LOGICAL      :: array_found
     7340    LOGICAL      :: ldum
     7341
     7342
     7343    CALL rd_mpi_io_check_array( 'c_liq_av', found = array_found )
     7344    IF ( array_found )  THEN
     7345       IF ( .NOT. ALLOCATED( c_liq_av ) )  ALLOCATE( c_liq_av(nysg:nyng,nxlg:nxrg) )
     7346       CALL rrd_mpi_io( 'c_liq_av',  c_liq_av )
     7347    ENDIF
     7348
     7349    CALL rd_mpi_io_check_array( 'c_soil_av', found = array_found )
     7350    IF ( array_found )  THEN
     7351       IF ( .NOT. ALLOCATED( c_soil_av ) )  ALLOCATE( c_soil_av(nysg:nyng,nxlg:nxrg) )
     7352       CALL rrd_mpi_io( 'c_soil_av',  c_soil_av )
     7353    ENDIF
     7354
     7355    CALL rd_mpi_io_check_array( 'c_veg_av', found = array_found )
     7356    IF ( array_found )  THEN
     7357       IF ( .NOT. ALLOCATED( c_veg_av ) )  ALLOCATE( c_veg_av(nysg:nyng,nxlg:nxrg) )
     7358       CALL rrd_mpi_io( 'c_veg_av',  c_veg_av )
     7359    ENDIF
     7360
     7361    CALL rd_mpi_io_check_array( 'lai_av', found = array_found )
     7362    IF ( array_found )  THEN
     7363       IF ( .NOT. ALLOCATED( lai_av ) )  ALLOCATE( lai_av(nysg:nyng,nxlg:nxrg) )
     7364       CALL rrd_mpi_io( 'lai_av',  lai_av )
     7365    ENDIF
     7366
     7367    CALL rd_mpi_io_check_array( 'm_liq_av', found = array_found )
     7368    IF ( array_found )  THEN
     7369       IF ( .NOT. ALLOCATED( m_liq_av ) )  ALLOCATE( m_liq_av(nysg:nyng,nxlg:nxrg) )
     7370       CALL rrd_mpi_io( 'm_liq_av',  m_liq_av )
     7371    ENDIF
     7372
     7373    CALL rd_mpi_io_check_array( 'm_soil_av', found = array_found )
     7374    IF ( array_found )  THEN
     7375       IF ( .NOT. ALLOCATED( m_soil_av ) )  ALLOCATE( m_soil_av(nzb_soil:nzt_soil,nysg:nyng,nxlg:nxrg) )
     7376       CALL rrd_mpi_io( 'm_soil_av', m_soil_av, nzb_soil, nzt_soil )
     7377    ENDIF
     7378
     7379    CALL rd_mpi_io_check_array( 'qsws_liq_av', found = array_found )
     7380    IF ( array_found )  THEN
     7381       IF ( .NOT. ALLOCATED( qsws_liq_av ) )  ALLOCATE( qsws_liq_av(nysg:nyng,nxlg:nxrg) )
     7382       CALL rrd_mpi_io( 'qsws_liq_av',  qsws_liq_av )
     7383    ENDIF
     7384
     7385    CALL rd_mpi_io_check_array( 'qsws_soil_av', found = array_found )
     7386    IF ( array_found )  THEN
     7387       IF ( .NOT. ALLOCATED( qsws_soil_av ) )  ALLOCATE( qsws_soil_av(nysg:nyng,nxlg:nxrg) )
     7388       CALL rrd_mpi_io( 'qsws_soil_av',  qsws_soil_av )
     7389    ENDIF
     7390
     7391    CALL rd_mpi_io_check_array( 'qsws_veg_av', found = array_found )
     7392    IF ( array_found )  THEN
     7393       IF ( .NOT. ALLOCATED( qsws_veg_av ) )  ALLOCATE( qsws_veg_av(nysg:nyng,nxlg:nxrg) )
     7394       CALL rrd_mpi_io( 'qsws_veg_av',  qsws_veg_av )
     7395    ENDIF
     7396
     7397    CALL rd_mpi_io_check_array( 't_soil_av', found = array_found )
     7398    IF ( array_found )  THEN
     7399       IF ( .NOT. ALLOCATED( t_soil_av ) )  ALLOCATE( t_soil_av(nzb_soil:nzt_soil,nysg:nyng,nxlg:nxrg) )
     7400       CALL rrd_mpi_io( 't_soil_av', t_soil_av, nzb_soil, nzt_soil )
     7401    ENDIF
     7402
     7403    CALL rrd_mpi_io( 'lsm_start_index_h',  surf_lsm_h%start_index )
     7404    CALL rrd_mpi_io( 'lsm_end_index_h',  surf_lsm_h%end_index )
     7405    CALL rrd_mpi_io( 'lsm_global_start_index_h', global_start )
     7406
     7407    CALL rd_mpi_io_surface_filetypes ( surf_lsm_h%start_index, surf_lsm_h%end_index, ldum,         &
     7408                                       global_start )
     7409
     7410    CALL rrd_mpi_io_surface( 't_soil_h', t_soil_h%var_2d )
     7411    CALL rrd_mpi_io_surface( 'm_soil_h',  m_soil_h%var_2d )
     7412    CALL rrd_mpi_io_surface( 'm_liq_h', m_liq_h%var_1d )
     7413    CALL rrd_mpi_io_surface( 't_surface_h', t_surface_h%var_1d )
     7414
     7415
     7416    DO  l = 0, 3
     7417
     7418       WRITE( dum, '(I1)')  l
     7419
     7420!kk    In case of nothing to do, the settings of start_index and end_index differ
     7421!kk    between writing and reading restart file
     7422!kk
     7423!kk    Has to be discussed with the developpers
     7424
     7425       CALL rrd_mpi_io( 'lsm_start_index_v_' // dum,  start_index )
     7426       CALL rrd_mpi_io( 'lsm_end_index_v_' // dum,  end_index )
     7427       CALL rrd_mpi_io( 'lsm_global_start_index_v_' // dum , global_start )
     7428
     7429       CALL rd_mpi_io_surface_filetypes( start_index, end_index, ldum, global_start )
     7430
     7431       IF ( MAXVAL( end_index ) <= 0 )  CYCLE
     7432
     7433       CALL rrd_mpi_io_surface( 't_soil_v(' // dum // ')', t_soil_v(l)%var_2d )
     7434       CALL rrd_mpi_io_surface( 'm_soil_v(' // dum // ')', m_soil_v(l)%var_2d )
     7435       CALL rrd_mpi_io_surface( 'm_liq_v(' // dum // ')',  m_liq_v(l)%var_1d )
     7436       CALL rrd_mpi_io_surface( 't_surface_v(' // dum // ')',  t_surface_v(l)%var_1d )
     7437
     7438    ENDDO
     7439
     7440 END SUBROUTINE lsm_rrd_local_mpi
    73087441
    73097442!------------------------------------------------------------------------------!
  • palm/trunk/SOURCE/module_interface.f90

    r4514 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4514 2020-04-30 16:29:59Z suehring
    2730! Added global restart routines for plant-canopy model
    2831!
     
    704707
    705708    INTERFACE module_interface_rrd_local
    706        MODULE PROCEDURE module_interface_rrd_local
     709       MODULE PROCEDURE module_interface_rrd_local_ftn
     710       MODULE PROCEDURE module_interface_rrd_local_mpi
    707711    END INTERFACE module_interface_rrd_local
    708712
     
    18061810! Description:
    18071811! ------------
    1808 !> Read module-specific restart data specific to local MPI ranks
    1809 !------------------------------------------------------------------------------!
    1810  SUBROUTINE module_interface_rrd_local( map_index,                             &
    1811                                         nxlf, nxlc, nxl_on_file,               &
    1812                                         nxrf, nxrc, nxr_on_file,               &
    1813                                         nynf, nync, nyn_on_file,               &
    1814                                         nysf, nysc, nys_on_file,               &
    1815                                         tmp_2d, tmp_3d, found )
     1812!> Read module-specific local restart data arrays (Fortran binary format).
     1813!------------------------------------------------------------------------------!
     1814 SUBROUTINE module_interface_rrd_local_ftn( map_index,                             &
     1815                                           nxlf, nxlc, nxl_on_file,               &
     1816                                           nxrf, nxrc, nxr_on_file,               &
     1817                                           nynf, nync, nyn_on_file,               &
     1818                                           nysf, nysc, nys_on_file,               &
     1819                                           tmp_2d, tmp_3d, found )
    18161820
    18171821
     
    18391843
    18401844
    1841     IF ( debug_output )  CALL debug_message( 'module-specific read local restart data', 'start' )
     1845    IF ( debug_output )  THEN
     1846       CALL debug_message( 'module-specific read local restart data (Fortran binary)', 'start' )
     1847    ENDIF
    18421848
    18431849    CALL dynamics_rrd_local(                                                   &
     
    19651971                            ) ! ToDo: change interface to pass variable
    19661972
    1967     IF ( debug_output )  CALL debug_message( 'module-specific read local restart data', 'end' )
    1968 
    1969 
    1970  END SUBROUTINE module_interface_rrd_local
     1973    IF ( debug_output )  THEN
     1974       CALL debug_message( 'module-specific read local restart data (Fortran binary)', 'end' )
     1975    ENDIF
     1976
     1977 END SUBROUTINE module_interface_rrd_local_ftn
     1978
     1979
     1980!------------------------------------------------------------------------------!
     1981! Description:
     1982! ------------
     1983!> Read module-specific local restart data arrays (MPI-IO).
     1984!------------------------------------------------------------------------------!
     1985 SUBROUTINE module_interface_rrd_local_mpi
     1986
     1987    IF ( debug_output )  THEN
     1988       CALL debug_message( 'module-specific read local restart data (MPI-IO)', 'start' )
     1989    ENDIF
     1990
     1991    CALL dynamics_rrd_local
     1992
     1993!    IF ( biometeorology )       CALL bio_rrd_local
     1994    IF ( bulk_cloud_model )     CALL bcm_rrd_local
     1995    IF ( air_chemistry )        CALL chem_rrd_local
     1996!    CALL doq_rrd_local
     1997    IF ( gust_module_enabled )  CALL gust_rrd_local
     1998    IF ( particle_advection )   CALL lpm_rrd_local
     1999    IF ( land_surface )         CALL lsm_rrd_local
     2000    IF ( plant_canopy )         CALL pcm_rrd_local
     2001    IF ( ocean_mode )           CALL ocean_rrd_local
     2002    IF ( radiation )            CALL radiation_rrd_local
     2003!    IF ( salsa )                CALL salsa_rrd_local
     2004    IF ( urban_surface )        CALL usm_rrd_local
     2005    IF ( surface_output )       CALL surface_data_output_rrd_local
     2006
     2007    IF ( user_module_enabled )  CALL user_rrd_local
     2008
     2009    IF ( debug_output )  THEN
     2010       CALL debug_message( 'module-specific read local restart data (Fortran binary)', 'end' )
     2011    ENDIF
     2012
     2013 END SUBROUTINE module_interface_rrd_local_mpi
    19712014
    19722015
  • palm/trunk/SOURCE/ocean_mod.f90

    r4495 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4495 2020-04-13 20:11:20Z raasch
    2730! restart data handling with MPI-IO added
    2831!
     
    102105
    103106    USE restart_data_mpi_io_mod,                                                                   &
    104         ONLY:  rrd_mpi_io, rrd_mpi_io_global_array, wrd_mpi_io, wrd_mpi_io_global_array
     107        ONLY:  rd_mpi_io_check_array, rrd_mpi_io, rrd_mpi_io_global_array, wrd_mpi_io,             &
     108               wrd_mpi_io_global_array
    105109
    106110    USE surface_mod,                                                           &
     
    232236
    233237    INTERFACE ocean_rrd_local
    234        MODULE PROCEDURE ocean_rrd_local
     238       MODULE PROCEDURE ocean_rrd_local_ftn
     239       MODULE PROCEDURE ocean_rrd_local_mpi
    235240    END INTERFACE ocean_rrd_local
    236241
     
    20392044! Description:
    20402045! ------------
    2041 !> This routine reads the respective restart data for the ocean module.
    2042 !------------------------------------------------------------------------------!
    2043  SUBROUTINE ocean_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,           &
    2044                              nxr_on_file, nynf, nync, nyn_on_file, nysf,       &
    2045                              nysc, nys_on_file, tmp_3d, found )
     2046!> Read module-specific local restart data arrays (Fortran binary format).
     2047!------------------------------------------------------------------------------!
     2048 SUBROUTINE ocean_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,           &
     2049                                 nxr_on_file, nynf, nync, nyn_on_file, nysf,       &
     2050                                 nysc, nys_on_file, tmp_3d, found )
    20462051
    20472052    USE averaging,                                                             &
     
    21082113    END SELECT
    21092114
    2110  END SUBROUTINE ocean_rrd_local
     2115 END SUBROUTINE ocean_rrd_local_ftn
     2116
     2117
     2118!------------------------------------------------------------------------------!
     2119! Description:
     2120! ------------
     2121!> Read module-specific local restart data arrays (MPI-IO).
     2122!------------------------------------------------------------------------------!
     2123 SUBROUTINE ocean_rrd_local_mpi
     2124
     2125    USE averaging,                                                             &
     2126        ONLY:  rho_ocean_av, sa_av
     2127
     2128    USE indices,                                                               &
     2129        ONLY:  nxlg, nxrg, nyng, nysg, nzb, nzt
     2130
     2131    IMPLICIT NONE
     2132
     2133    LOGICAL ::  array_found  !<
     2134
     2135
     2136    CALL rd_mpi_io_check_array( 'rho_ocean_av' , found = array_found )
     2137    IF ( array_found )  THEN
     2138       IF ( .NOT. ALLOCATED( rho_ocean_av ) )  ALLOCATE( rho_ocean_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2139       CALL rrd_mpi_io( 'rho_ocean_av', rho_ocean_av )
     2140    ENDIF
     2141
     2142    CALL rrd_mpi_io( 'sa', sa )
     2143
     2144    CALL rd_mpi_io_check_array( 'sa_av' , found = array_found )
     2145    IF ( array_found )  THEN
     2146       IF ( .NOT. ALLOCATED( sa_av ) )  ALLOCATE( sa_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2147       CALL rrd_mpi_io( 'sa_av', sa_av )
     2148    ENDIF
     2149
     2150 END SUBROUTINE ocean_rrd_local_mpi
    21112151
    21122152
  • palm/trunk/SOURCE/plant_canopy_model_mod.f90

    r4515 r4517  
    2727! -----------------
    2828! $Id$
     29! added restart with MPI-IO for reading local arrays
     30!
     31! 4515 2020-04-30 16:37:18Z suehring
    2932! Rename error number again since this was recently given in -r 4511
    3033!
     
    237240
    238241    USE restart_data_mpi_io_mod,                                                                   &
    239         ONLY:  rrd_mpi_io,                                                                         &
     242        ONLY:  rd_mpi_io_check_array,                                                              &
     243               rrd_mpi_io,                                                                         &
    240244               wrd_mpi_io
    241245
     
    361365
    362366    INTERFACE pcm_rrd_local
    363        MODULE PROCEDURE pcm_rrd_local
     367       MODULE PROCEDURE pcm_rrd_local_ftn
     368       MODULE PROCEDURE pcm_rrd_local_mpi
    364369    END INTERFACE pcm_rrd_local
    365370
     
    16851690    END SUBROUTINE pcm_rrd_global_mpi
    16861691
     1692
    16871693!------------------------------------------------------------------------------!
    16881694! Description:
    16891695! ------------
    1690 !> Subroutine reads local (subdomain) restart data
    1691 !------------------------------------------------------------------------------!
    1692     SUBROUTINE pcm_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
    1693                               nxr_on_file, nynf, nync, nyn_on_file, nysf,      &
    1694                               nysc, nys_on_file, found )
     1696!> Read module-specific local restart data arrays (Fortran binary format).
     1697!------------------------------------------------------------------------------!
     1698    SUBROUTINE pcm_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,          &
     1699                                  nxr_on_file, nynf, nync, nyn_on_file, nysf,      &
     1700                                  nysc, nys_on_file, found )
    16951701
    16961702       INTEGER(iwp) ::  k               !<
     
    17511757       END SELECT
    17521758
    1753     END SUBROUTINE pcm_rrd_local
     1759    END SUBROUTINE pcm_rrd_local_ftn
     1760
     1761
     1762!------------------------------------------------------------------------------!
     1763! Description:
     1764! ------------
     1765!> Read module-specific local restart data arrays (MPI-IO).
     1766!------------------------------------------------------------------------------!
     1767    SUBROUTINE pcm_rrd_local_mpi
     1768
     1769       IMPLICIT NONE
     1770
     1771       LOGICAL ::  array_found  !<
     1772
     1773
     1774!>     TODO: following code does not work because arrays are sized 0:pch_index along k!!!!!
     1775       CALL rd_mpi_io_check_array( 'pcm_heatrate_av' , found = array_found )
     1776       IF ( array_found )  THEN
     1777          IF ( .NOT. ALLOCATED( pcm_heatrate_av ) )  ALLOCATE( pcm_heatrate_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1778          CALL rrd_mpi_io( 'pcm_heatrate_av', pcm_heatrate_av )
     1779       ENDIF
     1780
     1781       CALL rd_mpi_io_check_array( 'pcm_latentrate_av' , found = array_found )
     1782       IF ( array_found )  THEN
     1783          IF ( .NOT. ALLOCATED( pcm_latentrate_av ) )  ALLOCATE( pcm_latentrate_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1784          CALL rrd_mpi_io( 'pcm_latentrate_av', pcm_latentrate_av )
     1785       ENDIF
     1786
     1787       CALL rd_mpi_io_check_array( 'pcm_transpirationrate_av' , found = array_found )
     1788       IF ( array_found )  THEN
     1789          IF ( .NOT. ALLOCATED( pcm_transpirationrate_av ) )  ALLOCATE( pcm_transpirationrate_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1790          CALL rrd_mpi_io( 'pcm_transpirationrate_av', pcm_transpirationrate_av )
     1791       ENDIF
     1792
     1793    END SUBROUTINE pcm_rrd_local_mpi
     1794
    17541795
    17551796!------------------------------------------------------------------------------!
  • palm/trunk/SOURCE/radiation_model_mod.f90

    r4495 r4517  
    2828! -----------------
    2929! $Id$
     30! added restart with MPI-IO for reading local arrays
     31!
     32! 4495 2020-04-13 20:11:20Z raasch
    3033! restart data handling with MPI-IO added
    3134!
     
    364367#endif
    365368    USE restart_data_mpi_io_mod,                                                                   &
    366         ONLY:  wrd_mpi_io
     369        ONLY:  rd_mpi_io_check_array, rrd_mpi_io, wrd_mpi_io
    367370
    368371    USE statistics,                                                            &
     
    971974
    972975    INTERFACE radiation_rrd_local
    973        MODULE PROCEDURE radiation_rrd_local
     976       MODULE PROCEDURE radiation_rrd_local_ftn
     977       MODULE PROCEDURE radiation_rrd_local_mpi
    974978    END INTERFACE radiation_rrd_local
    975979
     
    1208012084! Description:
    1208112085! ------------
    12082 !> Subroutine reads local (subdomain) restart data
     12086!> Read module-specific local restart data arrays (Fortran binary format).
    1208312087!------------------------------------------------------------------------------!
    12084  SUBROUTINE radiation_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,       &
    12085                                 nxr_on_file, nynf, nync, nyn_on_file, nysf,    &
    12086                                 nysc, nys_on_file, tmp_2d, tmp_3d, found )
     12088 SUBROUTINE radiation_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc,       &
     12089                                     nxr_on_file, nynf, nync, nyn_on_file, nysf,    &
     12090                                     nysc, nys_on_file, tmp_2d, tmp_3d, found )
    1208712091
    1208812092
     
    1242812432    END SELECT
    1242912433
    12430  END SUBROUTINE radiation_rrd_local
    12431 
     12434 END SUBROUTINE radiation_rrd_local_ftn
     12435
     12436
     12437!------------------------------------------------------------------------------!
     12438! Description:
     12439! ------------
     12440!> Read module-specific local restart data arrays (MPI-IO).
     12441!------------------------------------------------------------------------------!
     12442 SUBROUTINE radiation_rrd_local_mpi
     12443
     12444    USE control_parameters
     12445
     12446    USE indices
     12447
     12448    USE kinds
     12449
     12450
     12451    IMPLICIT NONE
     12452
     12453    LOGICAL      ::  array_found  !<
     12454
     12455    REAL(wp), DIMENSION(nysg:nyng,nxlg:nxrg) ::  tmp  !< temporary array for reading from file
     12456
     12457
     12458    CALL rd_mpi_io_check_array( 'rad_net_av' , found = array_found )
     12459    IF ( array_found )  THEN
     12460       IF ( .NOT. ALLOCATED( rad_net_av ) )  ALLOCATE( rad_net_av(nysg:nyng,nxlg:nxrg) )
     12461       CALL rrd_mpi_io( 'rad_net_av', rad_net_av )
     12462    ENDIF
     12463
     12464    CALL rd_mpi_io_check_array( 'rad_lw_in_xy_av' , found = array_found )
     12465    IF ( array_found )  THEN
     12466       IF ( .NOT. ALLOCATED( rad_lw_in_xy_av ) )  ALLOCATE( rad_lw_in_xy_av(nysg:nyng,nxlg:nxrg) )
     12467       CALL rrd_mpi_io( 'rad_lw_in_xy_av', rad_lw_in_xy_av )
     12468    ENDIF
     12469
     12470    CALL rd_mpi_io_check_array( 'rad_lw_out_xy_av' , found = array_found )
     12471    IF ( array_found )  THEN
     12472       IF ( .NOT. ALLOCATED( rad_lw_out_xy_av ) )  ALLOCATE( rad_lw_out_xy_av(nysg:nyng,nxlg:nxrg) )
     12473       CALL rrd_mpi_io( 'rad_lw_out_xy_av', rad_lw_out_xy_av )
     12474    ENDIF
     12475
     12476    CALL rd_mpi_io_check_array( 'rad_sw_in_xy_av' , found = array_found )
     12477    IF ( array_found )  THEN
     12478       IF ( .NOT. ALLOCATED( rad_sw_in_xy_av ) )  ALLOCATE( rad_sw_in_xy_av(nysg:nyng,nxlg:nxrg) )
     12479       CALL rrd_mpi_io( 'rad_sw_in_xy_av', rad_sw_in_xy_av )
     12480    ENDIF
     12481
     12482    CALL rd_mpi_io_check_array( 'rad_sw_out_xy_av' , found = array_found )
     12483    IF ( array_found )  THEN
     12484       IF ( .NOT. ALLOCATED( rad_sw_out_xy_av ) )  ALLOCATE( rad_sw_out_xy_av(nysg:nyng,nxlg:nxrg) )
     12485       CALL rrd_mpi_io( 'rad_sw_out_xy_av', rad_sw_out_xy_av )
     12486    ENDIF
     12487
     12488    CALL rd_mpi_io_check_array( 'rad_lw_in' , found = array_found )
     12489    IF ( array_found )  THEN
     12490       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12491            radiation_scheme == 'external' )  THEN
     12492          IF ( .NOT. ALLOCATED( rad_lw_in ) )  ALLOCATE( rad_lw_in(0:0,nysg:nyng,nxlg:nxrg) )
     12493          CALL rrd_mpi_io( 'rad_lw_in', tmp )
     12494          rad_lw_in(0,:,:) = tmp
     12495       ELSE
     12496          IF ( .NOT. ALLOCATED( rad_lw_in ) )  ALLOCATE( rad_lw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12497          CALL rrd_mpi_io( 'rad_lw_in', rad_lw_in )
     12498       ENDIF
     12499    ENDIF
     12500
     12501    CALL rd_mpi_io_check_array( 'rad_lw_in_av' , found = array_found )
     12502    IF ( array_found )  THEN
     12503       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12504            radiation_scheme == 'external' )  THEN
     12505          IF ( .NOT. ALLOCATED( rad_lw_in_av ) )  ALLOCATE( rad_lw_in_av(0:0,nysg:nyng,nxlg:nxrg) )
     12506          CALL rrd_mpi_io( 'rad_lw_in_av', tmp )
     12507          rad_lw_in_av(0,:,:) = tmp
     12508       ELSE
     12509          IF ( .NOT. ALLOCATED( rad_lw_in_av ) )  ALLOCATE( rad_lw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12510          CALL rrd_mpi_io( 'rad_lw_in_av', rad_lw_in_av )
     12511       ENDIF
     12512    ENDIF
     12513
     12514    CALL rd_mpi_io_check_array( 'rad_lw_out' , found = array_found )
     12515    IF ( array_found )  THEN
     12516       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12517            radiation_scheme == 'external' )  THEN
     12518          IF ( .NOT. ALLOCATED( rad_lw_out ) )  ALLOCATE( rad_lw_out(0:0,nysg:nyng,nxlg:nxrg) )
     12519          CALL rrd_mpi_io( 'rad_lw_out', tmp )
     12520          rad_lw_out(0,:,:) = tmp
     12521       ELSE
     12522          IF ( .NOT. ALLOCATED( rad_lw_out ) )  ALLOCATE( rad_lw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12523          CALL rrd_mpi_io( 'rad_lw_out', rad_lw_out )
     12524       ENDIF
     12525    ENDIF
     12526
     12527    CALL rd_mpi_io_check_array( 'rad_lw_out_av' , found = array_found )
     12528    IF ( array_found )  THEN
     12529       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12530            radiation_scheme == 'external' )  THEN
     12531          IF ( .NOT. ALLOCATED( rad_lw_out_av ) )  ALLOCATE( rad_lw_out_av(0:0,nysg:nyng,nxlg:nxrg) )
     12532          CALL rrd_mpi_io( 'rad_lw_out_av', tmp )
     12533          rad_lw_out_av(0,:,:) = tmp
     12534       ELSE
     12535          IF ( .NOT. ALLOCATED( rad_lw_out_av ) )  ALLOCATE( rad_lw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12536          CALL rrd_mpi_io( 'rad_lw_out_av', rad_lw_out_av )
     12537       ENDIF
     12538    ENDIF
     12539
     12540    CALL rd_mpi_io_check_array( 'rad_lw_cs_hr' , found = array_found )
     12541    IF ( array_found )  THEN
     12542       IF ( .NOT. ALLOCATED( rad_lw_cs_hr ) )  ALLOCATE( rad_lw_cs_hr(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12543       CALL rrd_mpi_io( 'rad_lw_cs_hr', rad_lw_cs_hr )
     12544    ENDIF
     12545
     12546    CALL rd_mpi_io_check_array( 'rad_lw_cs_hr_av' , found = array_found )
     12547    IF ( array_found )  THEN
     12548       IF ( .NOT. ALLOCATED( rad_lw_cs_hr_av ) )  ALLOCATE( rad_lw_cs_hr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12549       CALL rrd_mpi_io( 'rad_lw_cs_hr_av', rad_lw_cs_hr_av )
     12550    ENDIF
     12551
     12552    CALL rd_mpi_io_check_array( 'rad_lw_hr' , found = array_found )
     12553    IF ( array_found )  THEN
     12554       IF ( .NOT. ALLOCATED( rad_lw_hr ) )  ALLOCATE( rad_lw_hr(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12555       CALL rrd_mpi_io( 'rad_lw_hr', rad_lw_hr )
     12556    ENDIF
     12557
     12558    CALL rd_mpi_io_check_array( 'rad_lw_hr_av' , found = array_found )
     12559    IF ( array_found )  THEN
     12560       IF ( .NOT. ALLOCATED( rad_lw_hr_av ) )  ALLOCATE( rad_lw_hr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12561       CALL rrd_mpi_io( 'rad_lw_hr_av', rad_lw_hr_av )
     12562    ENDIF
     12563
     12564    CALL rd_mpi_io_check_array( 'rad_sw_in' , found = array_found )
     12565    IF ( array_found )  THEN
     12566       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12567            radiation_scheme == 'external' )  THEN
     12568          IF ( .NOT. ALLOCATED( rad_sw_in ) )  ALLOCATE( rad_sw_in(0:0,nysg:nyng,nxlg:nxrg) )
     12569          CALL rrd_mpi_io( 'rad_sw_in', tmp )
     12570          rad_sw_in(0,:,:) = tmp
     12571       ELSE
     12572          IF ( .NOT. ALLOCATED( rad_sw_in ) )  ALLOCATE( rad_sw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12573          CALL rrd_mpi_io( 'rad_sw_in', rad_sw_in )
     12574       ENDIF
     12575    ENDIF
     12576
     12577    CALL rd_mpi_io_check_array( 'rad_sw_in_av' , found = array_found )
     12578    IF ( array_found )  THEN
     12579       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12580            radiation_scheme == 'external' )  THEN
     12581          IF ( .NOT. ALLOCATED( rad_sw_in_av ) )  ALLOCATE( rad_sw_in_av(0:0,nysg:nyng,nxlg:nxrg) )
     12582          CALL rrd_mpi_io( 'rad_sw_in_av', tmp )
     12583          rad_sw_in_av(0,:,:) = tmp
     12584       ELSE
     12585          IF ( .NOT. ALLOCATED( rad_sw_in_av ) )  ALLOCATE( rad_sw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12586          CALL rrd_mpi_io( 'rad_sw_in_av', rad_sw_in_av )
     12587       ENDIF
     12588    ENDIF
     12589
     12590    CALL rd_mpi_io_check_array( 'rad_sw_out' , found = array_found )
     12591    IF ( array_found )  THEN
     12592       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12593            radiation_scheme == 'external' )  THEN
     12594          IF ( .NOT. ALLOCATED( rad_sw_out ) )  ALLOCATE( rad_sw_out(0:0,nysg:nyng,nxlg:nxrg) )
     12595          CALL rrd_mpi_io( 'rad_sw_out',  tmp)
     12596          rad_sw_out(0,:,:) = tmp
     12597       ELSE
     12598          IF ( .NOT. ALLOCATED( rad_sw_out ) )  ALLOCATE( rad_sw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12599          CALL rrd_mpi_io( 'rad_sw_out',  rad_sw_out )
     12600       ENDIF
     12601    ENDIF
     12602
     12603    CALL rd_mpi_io_check_array( 'rad_sw_out_av' , found = array_found )
     12604    IF ( array_found )  THEN
     12605       IF ( radiation_scheme == 'clear-sky'  .OR.  radiation_scheme == 'constant'  .OR.            &
     12606            radiation_scheme == 'external' )  THEN
     12607          IF ( .NOT. ALLOCATED( rad_sw_out_av ) )  ALLOCATE( rad_sw_out_av(0:0,nysg:nyng,nxlg:nxrg) )
     12608          CALL rrd_mpi_io( 'rad_sw_out_av', tmp )
     12609          rad_sw_out_av(0,:,:) = tmp
     12610       ELSE
     12611          IF ( .NOT. ALLOCATED( rad_sw_out_av ) )  ALLOCATE( rad_sw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12612          CALL rrd_mpi_io( 'rad_sw_out_av', rad_sw_out_av )
     12613       ENDIF
     12614    ENDIF
     12615
     12616    CALL rd_mpi_io_check_array( 'rad_sw_cs_hr' , found = array_found )
     12617    IF ( array_found )  THEN
     12618       IF ( .NOT. ALLOCATED( rad_sw_cs_hr ) )  ALLOCATE( rad_sw_cs_hr(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12619       CALL rrd_mpi_io( 'rad_sw_cs_hr', rad_sw_cs_hr )
     12620    ENDIF
     12621
     12622    CALL rd_mpi_io_check_array( 'rad_sw_cs_hr_av' , found = array_found )
     12623    IF ( array_found )  THEN
     12624       IF ( .NOT. ALLOCATED( rad_sw_cs_hr_av ) )  ALLOCATE( rad_sw_cs_hr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12625       CALL rrd_mpi_io( 'rad_sw_cs_hr_av', rad_sw_cs_hr_av )
     12626    ENDIF
     12627
     12628    CALL rd_mpi_io_check_array( 'rad_sw_hr' , found = array_found )
     12629    IF ( array_found )  THEN
     12630       IF ( .NOT. ALLOCATED( rad_sw_hr ) )  ALLOCATE( rad_sw_hr(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12631       CALL rrd_mpi_io( 'rad_sw_hr', rad_sw_hr )
     12632    ENDIF
     12633
     12634    CALL rd_mpi_io_check_array( 'rad_sw_hr_av' , found = array_found )
     12635    IF ( array_found )  THEN
     12636       IF ( .NOT. ALLOCATED( rad_sw_hr_av ) )  ALLOCATE( rad_sw_hr_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     12637       CALL rrd_mpi_io( 'rad_sw_hr_av', rad_sw_hr_av )
     12638    ENDIF
     12639
     12640 END SUBROUTINE radiation_rrd_local_mpi
    1243212641
    1243312642 END MODULE radiation_model_mod
  • palm/trunk/SOURCE/read_restart_data_mod.f90

    r4514 r4517  
    11471147
    11481148!
    1149 !--    Close restart File
     1149!--    Close restart file
    11501150       CALL rd_mpi_io_close
    11511151
     
    13761376! Description:
    13771377! ------------
    1378 !> Reads processor specific data of variables and arrays from restart file
     1378!> Reads processor (subdomain) specific data of variables and arrays from restart file
    13791379!> (binary format).
    13801380!------------------------------------------------------------------------------!
     
    13851385    CHARACTER (LEN=10) ::  binary_version_local
    13861386    CHARACTER (LEN=10) ::  version_on_file
     1387    CHARACTER (LEN=20) ::  tmp_name               !< temporary variable
    13871388
    13881389    INTEGER(iwp) ::  files_to_be_opened  !<
     
    14281429    INTEGER(isp), DIMENSION(:,:,:), ALLOCATABLE ::  tmp_2d_seq_random  !< temporary array for storing random generator data
    14291430
    1430     LOGICAL ::  found
     1431    LOGICAL ::  array_found                      !<
     1432    LOGICAL ::  found                            !<
    14311433
    14321434    REAL(wp), DIMENSION(:,:),   ALLOCATABLE   ::  tmp_2d         !< temporary array for storing 2D data
     
    14381440!-- Read data from previous model run.
    14391441    CALL cpu_log( log_point_s(14), 'rrd_local', 'start' )
    1440 !
    1441 !-- Allocate temporary buffer arrays. In previous versions, there were
    1442 !-- declared as automated arrays, causing memory problems when these
    1443 !-- were allocate on stack.
    1444     ALLOCATE( nxlfa(numprocs_previous_run,1000) )
    1445     ALLOCATE( nxrfa(numprocs_previous_run,1000) )
    1446     ALLOCATE( nynfa(numprocs_previous_run,1000) )
    1447     ALLOCATE( nysfa(numprocs_previous_run,1000) )
    1448     ALLOCATE( offset_xa(numprocs_previous_run,1000) )
    1449     ALLOCATE( offset_ya(numprocs_previous_run,1000) )
    1450 
    1451 !
    1452 !-- Check which of the restart files contain data needed for the subdomain
    1453 !-- of this PE
    1454     files_to_be_opened = 0
    1455 
    1456     DO  i = 1, numprocs_previous_run
    1457 !
    1458 !--    Store array bounds of the previous run ("pr") in temporary scalars
    1459        nxlpr = hor_index_bounds_previous_run(1,i-1)
    1460        nxrpr = hor_index_bounds_previous_run(2,i-1)
    1461        nyspr = hor_index_bounds_previous_run(3,i-1)
    1462        nynpr = hor_index_bounds_previous_run(4,i-1)
    1463 
    1464 !
    1465 !--    Determine the offsets. They may be non-zero in case that the total domain
    1466 !--    on file is smaller than the current total domain.
    1467        offset_x = ( nxl / ( nx_on_file + 1 ) ) * ( nx_on_file + 1 )
    1468        offset_y = ( nys / ( ny_on_file + 1 ) ) * ( ny_on_file + 1 )
    1469 
    1470 !
    1471 !--    Start with this offset and then check, if the subdomain on file
    1472 !--    matches another time(s) in the current subdomain by shifting it
    1473 !--    for nx_on_file+1, ny_on_file+1 respectively
    1474 
    1475        shift_y = 0
    1476        j       = 0
    1477        DO WHILE (  nyspr+shift_y <= nyn-offset_y )
    1478 
    1479           IF ( nynpr+shift_y >= nys-offset_y ) THEN
    1480 
    1481              shift_x = 0
    1482              DO WHILE ( nxlpr+shift_x <= nxr-offset_x )
    1483 
    1484                 IF ( nxrpr+shift_x >= nxl-offset_x ) THEN
    1485                    j = j +1
    1486                    IF ( j > 1000 )  THEN
    1487 !
    1488 !--                   Array bound exceeded
    1489                       message_string = 'data from subdomain of previous' //                        &
    1490                                        ' run mapped more than 1000 times'
    1491                       CALL message( 'rrd_local', 'PA0284', 2, 2, -1, 6, 1 )
     1442
     1443    IF ( TRIM( restart_data_format_input ) == 'fortran_binary' )  THEN
     1444!
     1445!--    Input in Fortran binary format
     1446
     1447!
     1448!--    Allocate temporary buffer arrays. In previous versions, there were
     1449!--    declared as automated arrays, causing memory problems when these
     1450!--    were allocate on stack.
     1451       ALLOCATE( nxlfa(numprocs_previous_run,1000) )
     1452       ALLOCATE( nxrfa(numprocs_previous_run,1000) )
     1453       ALLOCATE( nynfa(numprocs_previous_run,1000) )
     1454       ALLOCATE( nysfa(numprocs_previous_run,1000) )
     1455       ALLOCATE( offset_xa(numprocs_previous_run,1000) )
     1456       ALLOCATE( offset_ya(numprocs_previous_run,1000) )
     1457
     1458!
     1459!--    Check which of the restart files contain data needed for the subdomain
     1460!--    of this PE
     1461       files_to_be_opened = 0
     1462
     1463       DO  i = 1, numprocs_previous_run
     1464!
     1465!--       Store array bounds of the previous run ("pr") in temporary scalars
     1466          nxlpr = hor_index_bounds_previous_run(1,i-1)
     1467          nxrpr = hor_index_bounds_previous_run(2,i-1)
     1468          nyspr = hor_index_bounds_previous_run(3,i-1)
     1469          nynpr = hor_index_bounds_previous_run(4,i-1)
     1470
     1471!
     1472!--       Determine the offsets. They may be non-zero in case that the total domain
     1473!--       on file is smaller than the current total domain.
     1474          offset_x = ( nxl / ( nx_on_file + 1 ) ) * ( nx_on_file + 1 )
     1475          offset_y = ( nys / ( ny_on_file + 1 ) ) * ( ny_on_file + 1 )
     1476
     1477!
     1478!--       Start with this offset and then check, if the subdomain on file
     1479!--       matches another time(s) in the current subdomain by shifting it
     1480!--       for nx_on_file+1, ny_on_file+1 respectively
     1481
     1482          shift_y = 0
     1483          j       = 0
     1484          DO WHILE (  nyspr+shift_y <= nyn-offset_y )
     1485
     1486             IF ( nynpr+shift_y >= nys-offset_y ) THEN
     1487
     1488                shift_x = 0
     1489                DO WHILE ( nxlpr+shift_x <= nxr-offset_x )
     1490
     1491                   IF ( nxrpr+shift_x >= nxl-offset_x ) THEN
     1492                      j = j +1
     1493                      IF ( j > 1000 )  THEN
     1494!
     1495!--                      Array bound exceeded
     1496                         message_string = 'data from subdomain of previous' //                        &
     1497                                          ' run mapped more than 1000 times'
     1498                         CALL message( 'rrd_local', 'PA0284', 2, 2, -1, 6, 1 )
     1499                      ENDIF
     1500
     1501                      IF ( j == 1 )  THEN
     1502                         files_to_be_opened = files_to_be_opened + 1
     1503                         file_list(files_to_be_opened) = i-1
     1504                      ENDIF
     1505
     1506                      offset_xa(files_to_be_opened,j) = offset_x + shift_x
     1507                      offset_ya(files_to_be_opened,j) = offset_y + shift_y
     1508!
     1509!--                   Index bounds of overlapping data
     1510                      nxlfa(files_to_be_opened,j) = MAX( nxl-offset_x-shift_x, nxlpr )
     1511                      nxrfa(files_to_be_opened,j) = MIN( nxr-offset_x-shift_x, nxrpr )
     1512                      nysfa(files_to_be_opened,j) = MAX( nys-offset_y-shift_y, nyspr )
     1513                      nynfa(files_to_be_opened,j) = MIN( nyn-offset_y-shift_y, nynpr )
     1514
    14921515                   ENDIF
    14931516
    1494                    IF ( j == 1 )  THEN
    1495                       files_to_be_opened = files_to_be_opened + 1
    1496                       file_list(files_to_be_opened) = i-1
    1497                    ENDIF
    1498 
    1499                    offset_xa(files_to_be_opened,j) = offset_x + shift_x
    1500                    offset_ya(files_to_be_opened,j) = offset_y + shift_y
    1501 !
    1502 !--                Index bounds of overlapping data
    1503                    nxlfa(files_to_be_opened,j) = MAX( nxl-offset_x-shift_x, nxlpr )
    1504                    nxrfa(files_to_be_opened,j) = MIN( nxr-offset_x-shift_x, nxrpr )
    1505                    nysfa(files_to_be_opened,j) = MAX( nys-offset_y-shift_y, nyspr )
    1506                    nynfa(files_to_be_opened,j) = MIN( nyn-offset_y-shift_y, nynpr )
    1507 
    1508                 ENDIF
    1509 
    1510                 shift_x = shift_x + ( nx_on_file + 1 )
    1511              ENDDO
    1512 
     1517                   shift_x = shift_x + ( nx_on_file + 1 )
     1518                ENDDO
     1519
     1520             ENDIF
     1521
     1522             shift_y = shift_y + ( ny_on_file + 1 )
     1523          ENDDO
     1524
     1525          IF ( j > 0 )  overlap_count(files_to_be_opened) = j
     1526
     1527       ENDDO
     1528
     1529!
     1530!--    Save the id-string of the current process, since myid_char may now be used
     1531!--    to open files created by PEs with other id.
     1532       myid_char_save = myid_char
     1533
     1534       IF ( files_to_be_opened /= 1  .OR.  numprocs /= numprocs_previous_run )  THEN
     1535          WRITE( message_string, * ) 'number of PEs or virtual PE-grid changed in restart run. & ',   &
     1536                                     'Set debug_output =.T. to get a list of files from which the & ',&
     1537                                     'single PEs will read respectively'
     1538          CALL message( 'rrd_local', 'PA0285', 0, 0, 0, 6, 0 )
     1539          IF ( debug_output )  THEN
     1540             IF ( files_to_be_opened <= 120 )  THEN
     1541                WRITE( debug_string, '(2A,1X,120(I6.6,1X))' )                                         &
     1542                     'number of PEs or virtual PE-grid changed in restart run.  PE will read from ',  &
     1543                     'files ', file_list(1:files_to_be_opened)
     1544             ELSE
     1545                WRITE( debug_string, '(3A,1X,120(I6.6,1X),A)' )                                      &
     1546                     'number of PEs or virtual PE-grid changed in restart run.  PE will read from ',  &
     1547                     'files ', file_list(1:120), '... and more'
     1548             ENDIF
     1549             CALL debug_message( 'rrd_local', 'info' )
    15131550          ENDIF
    1514 
    1515           shift_y = shift_y + ( ny_on_file + 1 )
    1516        ENDDO
    1517 
    1518        IF ( j > 0 )  overlap_count(files_to_be_opened) = j
    1519 
    1520     ENDDO
    1521 
    1522 !
    1523 !-- Save the id-string of the current process, since myid_char may now be used
    1524 !-- to open files created by PEs with other id.
    1525     myid_char_save = myid_char
    1526 
    1527     IF ( files_to_be_opened /= 1  .OR.  numprocs /= numprocs_previous_run )  THEN
    1528        WRITE( message_string, * ) 'number of PEs or virtual PE-grid changed in restart run. & ',   &
    1529                                   'Set debug_output =.T. to get a list of files from which the & ',&
    1530                                   'single PEs will read respectively'
    1531        CALL message( 'rrd_local', 'PA0285', 0, 0, 0, 6, 0 )
    1532        IF ( debug_output )  THEN
    1533           IF ( files_to_be_opened <= 120 )  THEN
    1534              WRITE( debug_string, '(2A,1X,120(I6.6,1X))' )                                         &
    1535                   'number of PEs or virtual PE-grid changed in restart run.  PE will read from ',  &
    1536                   'files ', file_list(1:files_to_be_opened)
    1537           ELSE
    1538              WRITE( debug_string, '(3A,1X,120(I6.6,1X),A)' )                                      &
    1539                   'number of PEs or virtual PE-grid changed in restart run.  PE will read from ',  &
    1540                   'files ', file_list(1:120), '... and more'
    1541           ENDIF
    1542           CALL debug_message( 'rrd_local', 'info' )
    1543        ENDIF
    1544     ENDIF
    1545 
    1546 !
    1547 !-- Read data from all restart files determined above
    1548     DO  i = 1, files_to_be_opened
    1549 
    1550        j = file_list(i)
    1551 !
    1552 !--    Set the filename (underscore followed by four digit processor id)
    1553        WRITE (myid_char,'(''_'',I6.6)')  j
    1554 
    1555 !
    1556 !--    Open the restart file. If this file has been created by PE0 (_000000),
    1557 !--    the global variables at the beginning of the file have to be skipped
    1558 !--    first.
    1559        CALL check_open( 13 )
    1560        IF ( j == 0 )  CALL rrd_skip_global
    1561 
    1562 !
    1563 !--    First compare the version numbers
    1564        READ ( 13 )  length
    1565        READ ( 13 )  restart_string(1:length)
    1566        READ ( 13 )  version_on_file
    1567 
    1568        binary_version_local = '4.7'
    1569        IF ( TRIM( version_on_file ) /= TRIM( binary_version_local ) )  THEN
    1570           WRITE( message_string, * ) 'version mismatch concerning ',                               &
    1571                                      'binary_version_local:',                                      &
    1572                                      '&version on file    = "', TRIM( version_on_file ), '"',      &
    1573                                      '&version in program = "', TRIM( binary_version_local ), '"'
    1574           CALL message( 'rrd_local', 'PA0286', 1, 2, 0, 6, 0 )
    1575        ENDIF
    1576 
    1577 !
    1578 !--    Read number of processors, processor-id, and array ranges.
    1579 !--    Compare the array ranges with those stored in the index bound array.
    1580        READ ( 13 )  numprocs_on_file, myid_on_file, nxl_on_file, nxr_on_file, nys_on_file,         &
    1581                     nyn_on_file, nzb_on_file, nzt_on_file
    1582 
    1583        IF ( nxl_on_file /= hor_index_bounds_previous_run(1,j) )  THEN
    1584           WRITE( message_string, * ) 'problem with index bound nxl on ',                           &
    1585                                      'restart file "', myid_char, '"',                             &
    1586                                      '&nxl = ', nxl_on_file, ' but it should be',                  &
    1587                                      '&= ', hor_index_bounds_previous_run(1,j),                    &
    1588                                      '&from the index bound information array'
    1589           CALL message( 'rrd_local', 'PA0287', 2, 2, -1, 6, 1 )
    1590        ENDIF
    1591 
    1592        IF ( nxr_on_file /= hor_index_bounds_previous_run(2,j) )  THEN
    1593            WRITE( message_string, * ) 'problem with index bound nxr on ',                          &
    1594                                       'restart file "', myid_char, '"'  ,                          &
    1595                                       ' nxr = ', nxr_on_file, ' but it should be',                 &
    1596                                       ' = ', hor_index_bounds_previous_run(2,j),                   &
    1597                                       ' from the index bound information array'
    1598           CALL message( 'rrd_local', 'PA0288', 2, 2, -1, 6, 1 )
    1599 
    1600        ENDIF
    1601 
    1602        IF ( nys_on_file /= hor_index_bounds_previous_run(3,j) )  THEN
    1603           WRITE( message_string, * ) 'problem with index bound nys on ',                           &
    1604                                      'restart file "', myid_char, '"',                             &
    1605                                      '&nys = ', nys_on_file, ' but it should be',                  &
    1606                                      '&= ', hor_index_bounds_previous_run(3,j),                    &
    1607                                      '&from the index bound information array'
    1608           CALL message( 'rrd_local', 'PA0289', 2, 2, -1, 6, 1 )
    1609        ENDIF
    1610 
    1611        IF ( nyn_on_file /= hor_index_bounds_previous_run(4,j) )  THEN
    1612           WRITE( message_string, * ) 'problem with index bound nyn on ',                           &
    1613                                      'restart file "', myid_char, '"',                             &
    1614                                      '&nyn = ', nyn_on_file, ' but it should be',                  &
    1615                                      '&= ', hor_index_bounds_previous_run(4,j),                    &
    1616                                      '&from the index bound information array'
    1617           CALL message( 'rrd_local', 'PA0290', 2, 2, -1, 6, 1 )
    1618        ENDIF
    1619 
    1620        IF ( nzb_on_file /= nzb )  THEN
    1621           WRITE( message_string, * ) 'mismatch between actual data and data ',                     &
    1622                                      'from prior run on PE ', myid,                                &
    1623                                      '&nzb on file = ', nzb_on_file,                               &
    1624                                      '&nzb         = ', nzb
    1625           CALL message( 'rrd_local', 'PA0291', 1, 2, 0, 6, 0 )
    1626        ENDIF
    1627 
    1628        IF ( nzt_on_file /= nzt )  THEN
    1629           WRITE( message_string, * ) 'mismatch between actual data and data ',                     &
    1630                                      'from prior run on PE ', myid,                                &
    1631                                      '&nzt on file = ', nzt_on_file,                               &
    1632                                      '&nzt         = ', nzt
    1633           CALL message( 'rrd_local', 'PA0292', 1, 2, 0, 6, 0 )
    1634        ENDIF
    1635 
    1636 !
    1637 !--    Allocate temporary arrays sized as the arrays on the restart file
    1638        ALLOCATE( tmp_2d(nys_on_file-nbgp:nyn_on_file+nbgp,nxl_on_file-nbgp:nxr_on_file+nbgp),      &
    1639                  tmp_3d(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,                               &
    1640                         nxl_on_file-nbgp:nxr_on_file+nbgp) )
    1641 
    1642 !
    1643 !--    Read arrays
    1644 !--    ATTENTION: If the following read commands have been altered, the
    1645 !--    ---------- version number of the variable binary_version_local must
    1646 !--               be altered, too. Furthermore, the output list of arrays in
    1647 !--               wrd_write_local must also be altered
    1648 !--               accordingly.
    1649        READ ( 13 )  length
    1650        READ ( 13 )  restart_string(1:length)
    1651 
    1652 
    1653 !
    1654 !--    Loop over processor specific field data
    1655        DO  WHILE ( restart_string(1:length) /= '*** end ***' )
    1656 
    1657 !
    1658 !--       Map data on file as often as needed (data are read only for k=1)
    1659           DO  k = 1, overlap_count(i)
    1660 
    1661              found = .FALSE.
    1662 
    1663 !
    1664 !--          Get the index range of the subdomain on file which overlap with
    1665 !--          the current subdomain
    1666              nxlf = nxlfa(i,k)
    1667              nxlc = nxlfa(i,k) + offset_xa(i,k)
    1668              nxrf = nxrfa(i,k)
    1669              nxrc = nxrfa(i,k) + offset_xa(i,k)
    1670              nysf = nysfa(i,k)
    1671              nysc = nysfa(i,k) + offset_ya(i,k)
    1672              nynf = nynfa(i,k)
    1673              nync = nynfa(i,k) + offset_ya(i,k)
    1674 
    1675 
    1676              SELECT CASE ( restart_string(1:length) )
    1677 
    1678                 CASE ( 'ghf_av' )
    1679                    IF ( .NOT. ALLOCATED( ghf_av ) )  THEN
    1680                       ALLOCATE( ghf_av(nysg:nyng,nxlg:nxrg) )
    1681                    ENDIF
    1682                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1683                    ghf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1684                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1685 
    1686                 CASE ( 'e' )
    1687                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1688                    e(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    1689                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1690 
    1691                 CASE ( 'e_av' )
    1692                    IF ( .NOT. ALLOCATED( e_av ) )  THEN
    1693                       ALLOCATE( e_av(nzb:nzt+1,nys-nbgp:nyn+nbgp,                                  &
    1694                                      nxl-nbgp:nxr+nbgp) )
    1695                    ENDIF
    1696                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1697                    e_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1698                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1699 
    1700                 CASE ( 'kh' )
    1701                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1702                    kh(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
    1703                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1704 
    1705                 CASE ( 'kh_av' )
    1706                    IF ( .NOT. ALLOCATED( kh_av ) )  THEN
    1707                       ALLOCATE( kh_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
    1708                    ENDIF
    1709                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1710                    kh_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
    1711                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1712 
    1713                 CASE ( 'km' )
    1714                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1715                    km(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
    1716                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1717 
    1718                 CASE ( 'km_av' )
    1719                    IF ( .NOT. ALLOCATED( km_av ) )  THEN
    1720                       ALLOCATE( km_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
    1721                    ENDIF
    1722                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1723                    km_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
    1724                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1725 
    1726                 CASE ( 'lpt_av' )
    1727                    IF ( .NOT. ALLOCATED( lpt_av ) )  THEN
    1728                       ALLOCATE( lpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
    1729                    ENDIF
    1730                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1731                    lpt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
    1732                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1733 
    1734                 CASE ( 'lwp_av' )
    1735                    IF ( .NOT. ALLOCATED( lwp_av ) )  THEN
    1736                       ALLOCATE( lwp_av(nysg:nyng,nxlg:nxrg) )
    1737                    ENDIF
    1738                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1739                    lwp_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1740                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1741 
    1742                 CASE ( 'p' )
    1743                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1744                    p(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    1745                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1746 
    1747                 CASE ( 'p_av' )
    1748                    IF ( .NOT. ALLOCATED( p_av ) )  THEN
    1749                       ALLOCATE( p_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    1750                    ENDIF
    1751                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1752                    p_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1753                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1754 
    1755                 CASE ( 'pt' )
    1756                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1757                    pt(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
    1758                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1759 
    1760                 CASE ( 'pt_av' )
    1761                    IF ( .NOT. ALLOCATED( pt_av ) )  THEN
    1762                       ALLOCATE( pt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    1763                    ENDIF
    1764                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1765                    pt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
    1766                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1767 
    1768                 CASE ( 'pt_2m_av' )
    1769                    IF ( .NOT. ALLOCATED( pt_2m_av ) )  THEN
    1770                       ALLOCATE( pt_2m_av(nysg:nyng,nxlg:nxrg) )
    1771                    ENDIF
    1772                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1773                    pt_2m_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                            &
    1774                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1775 
    1776                 CASE ( 'q' )
    1777                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1778                    q(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    1779                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1780 
    1781                 CASE ( 'q_av' )
    1782                    IF ( .NOT. ALLOCATED( q_av ) )  THEN
    1783                       ALLOCATE( q_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
    1784                    ENDIF
    1785                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1786                    q_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1787                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1788 
    1789                 CASE ( 'ql' )
    1790                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1791                    ql(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
    1792                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1793 
    1794                 CASE ( 'ql_av' )
    1795                    IF ( .NOT. ALLOCATED( ql_av ) )  THEN
    1796                       ALLOCATE( ql_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    1797                    ENDIF
    1798                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1799                    ql_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
    1800                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1801 
    1802                 CASE ( 'qsurf_av' )
    1803                    IF ( .NOT. ALLOCATED( qsurf_av ) )  THEN
    1804                       ALLOCATE( qsurf_av(nysg:nyng,nxlg:nxrg) )
    1805                    ENDIF
    1806                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1807                    qsurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
    1808                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1809 
    1810                 CASE ( 'qsws_av' )
    1811                    IF ( .NOT. ALLOCATED( qsws_av ) )  THEN
    1812                       ALLOCATE( qsws_av(nysg:nyng,nxlg:nxrg) )
    1813                    ENDIF
    1814                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1815                    qsws_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                             &
    1816                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1817 
    1818                 CASE ( 'qv_av' )
    1819                    IF ( .NOT. ALLOCATED( qv_av ) )  THEN
    1820                       ALLOCATE( qv_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    1821                    ENDIF
    1822                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1823                    qv_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
    1824                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1825 
    1826                 CASE ( 'r_a_av' )
    1827                    IF ( .NOT. ALLOCATED( r_a_av ) )  THEN
    1828                       ALLOCATE( r_a_av(nysg:nyng,nxlg:nxrg) )
    1829                    ENDIF
    1830                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1831                    r_a_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1832                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1833 
    1834                 CASE ( 'random_iv' )  ! still unresolved issue
    1835                    IF ( k == 1 )  READ ( 13 )  random_iv
    1836                    IF ( k == 1 )  READ ( 13 )  random_iy
    1837 
    1838                 CASE ( 'seq_random_array' )
    1839                    ALLOCATE( tmp_2d_id_random(nys_on_file:nyn_on_file,nxl_on_file:nxr_on_file) )
    1840                    ALLOCATE( tmp_2d_seq_random(5,nys_on_file:nyn_on_file,nxl_on_file:nxr_on_file) )
    1841                    IF ( .NOT. ALLOCATED( id_random_array ) )  THEN
    1842                       ALLOCATE( id_random_array(nys:nyn,nxl:nxr) )
    1843                    ENDIF
    1844                    IF ( .NOT. ALLOCATED( seq_random_array ) )  THEN
    1845                       ALLOCATE( seq_random_array(5,nys:nyn,nxl:nxr) )
    1846                    ENDIF
    1847                    IF ( k == 1 )  READ ( 13 )  tmp_2d_id_random
    1848                    IF ( k == 1 )  READ ( 13 )  tmp_2d_seq_random
    1849                    id_random_array(nysc:nync,nxlc:nxrc) = tmp_2d_id_random(nysf:nynf,nxlf:nxrf)
    1850                    seq_random_array(:,nysc:nync,nxlc:nxrc) = tmp_2d_seq_random(:,nysf:nynf,nxlf:nxrf)
    1851                    DEALLOCATE( tmp_2d_id_random, tmp_2d_seq_random )
    1852 
    1853                 CASE ( 's' )
    1854                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1855                    s(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    1856                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1857 
    1858                 CASE ( 's_av' )
    1859                    IF ( .NOT. ALLOCATED( s_av ) )  THEN
    1860                       ALLOCATE( s_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg))
    1861                    ENDIF
    1862                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1863                    s_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1864                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1865 
    1866                 CASE ( 'shf_av' )
    1867                    IF ( .NOT. ALLOCATED( shf_av ) )  THEN
    1868                       ALLOCATE( shf_av(nysg:nyng,nxlg:nxrg) )
    1869                    ENDIF
    1870                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1871                    shf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
    1872                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1873 
    1874                 CASE ( 'ssurf_av' )
    1875                    IF ( .NOT. ALLOCATED( ssurf_av ) )  THEN
    1876                       ALLOCATE( ssurf_av(nysg:nyng,nxlg:nxrg) )
    1877                    ENDIF
    1878                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1879                    ssurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
    1880                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1881 
    1882                 CASE ( 'ssws_av' )
    1883                    IF ( .NOT. ALLOCATED( ssws_av ) )  THEN
    1884                       ALLOCATE( ssws_av(nysg:nyng,nxlg:nxrg) )
    1885                    ENDIF
    1886                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1887                    ssws_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                             &
    1888                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1889 
    1890                 CASE ( 'ti_av' )
    1891                    IF ( .NOT. ALLOCATED( ti_av ) )  THEN
    1892                       ALLOCATE( ti_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    1893                    ENDIF
    1894                    IF ( k == 1 )  THEN
    1895                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    1896                                                     nxl_on_file:nxr_on_file) )
    1897                       READ ( 13 )  tmp_3d_non_standard
    1898                    ENDIF
    1899                    ti_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    1900 
    1901                 CASE ( 'ts_av' )
    1902                    IF ( .NOT. ALLOCATED( ts_av ) )  THEN
    1903                       ALLOCATE( ts_av(nysg:nyng,nxlg:nxrg) )
    1904                    ENDIF
    1905                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1906                    ts_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
    1907                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1908 
    1909                 CASE ( 'tsurf_av' )
    1910                    IF ( .NOT. ALLOCATED( tsurf_av ) )  THEN
    1911                       ALLOCATE( tsurf_av(nysg:nyng,nxlg:nxrg) )
    1912                    ENDIF
    1913                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1914                    tsurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
    1915                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1916 
    1917                 CASE ( 'u' )
    1918                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1919                    u(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    1920                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1921 
    1922                 CASE ( 'u_av' )
    1923                    IF ( .NOT. ALLOCATED( u_av ) )  THEN
    1924                       ALLOCATE( u_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    1925                    ENDIF
    1926                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    1927                    u_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    1928                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1929 
    1930                 CASE ( 'u_center_av' )
    1931                    IF ( .NOT. ALLOCATED( u_center_av ) )  THEN
    1932                       ALLOCATE( u_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    1933                    ENDIF
    1934                    IF ( k == 1 )  THEN
    1935                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    1936                                                     nxl_on_file:nxr_on_file) )
    1937                       READ ( 13 )  tmp_3d_non_standard
    1938                    ENDIF
    1939                    u_center_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    1940 
    1941                 CASE ( 'uu_av' )
    1942                    IF ( .NOT. ALLOCATED( uu_av ) )  THEN
    1943                       ALLOCATE( uu_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    1944                    ENDIF
    1945                    IF ( k == 1 )  THEN
    1946                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    1947                                                     nxl_on_file:nxr_on_file) )
    1948                       READ ( 13 )  tmp_3d_non_standard
    1949                    ENDIF
    1950                    uu_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    1951 
    1952                 CASE ( 'uv_10m_av' )
    1953                    IF ( .NOT. ALLOCATED( uv_10m_av ) )  THEN
    1954                       ALLOCATE( uv_10m_av(nysg:nyng,nxlg:nxrg) )
    1955                    ENDIF
    1956                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    1957                    uv_10m_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                           &
    1958                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    1959 
    1960                 CASE ( 'u_m_l' )
    1961                    IF ( k == 1 )  THEN
    1962                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    1963                                                     1:2) )
    1964                       READ ( 13 )  tmp_3d_non_standard
    1965                    ENDIF
    1966                    IF ( bc_radiation_l )  THEN
    1967                       u_m_l(:,nysc-nbgp:nync+nbgp,:) =  tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    1968                    ENDIF
    1969 
    1970                 CASE ( 'u_m_n' )
    1971                    IF ( k == 1 )  THEN
    1972                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
    1973                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    1974                       READ ( 13 )  tmp_3d_non_standard
    1975                    ENDIF
    1976                    IF ( bc_radiation_n )  THEN
    1977                       u_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    1978                    ENDIF
    1979 
    1980                 CASE ( 'u_m_r' )
    1981                    IF ( k == 1 )  THEN
    1982                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    1983                                                     nx-1:nx) )
    1984                       READ ( 13 )  tmp_3d_non_standard
    1985                    ENDIF
    1986                    IF ( bc_radiation_r )  THEN
    1987                       u_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    1988                    ENDIF
    1989 
    1990                 CASE ( 'u_m_s' )
    1991                    IF ( k == 1 )  THEN
    1992                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,0:1,                                 &
    1993                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    1994                       READ ( 13 )  tmp_3d_non_standard
    1995                    ENDIF
    1996                    IF ( bc_radiation_s )  THEN
    1997                       u_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    1998                    ENDIF
    1999 
    2000                 CASE ( 'us_av' )
    2001                    IF ( .NOT. ALLOCATED( us_av ) )  THEN
    2002                       ALLOCATE( us_av(nysg:nyng,nxlg:nxrg) )
    2003                    ENDIF
    2004                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    2005                    us_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
    2006                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2007 
    2008                 CASE ( 'v' )
    2009                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2010                    v(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    2011                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2012 
    2013                 CASE ( 'v_av' )
    2014                    IF ( .NOT. ALLOCATED( v_av ) )  THEN
    2015                       ALLOCATE( v_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    2016                    ENDIF
    2017                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2018                    v_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    2019                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2020 
    2021                 CASE ( 'v_center_av' )
    2022                    IF ( .NOT. ALLOCATED( v_center_av ) )  THEN
    2023                       ALLOCATE( v_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    2024                    ENDIF
    2025                    IF ( k == 1 )  THEN
    2026                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    2027                                                     nxl_on_file:nxr_on_file) )
    2028                       READ ( 13 )  tmp_3d_non_standard
    2029                    ENDIF
    2030                    v_center_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    2031 
    2032                 CASE ( 'vv_av' )
    2033                    IF ( .NOT. ALLOCATED( vv_av ) )  THEN
    2034                       ALLOCATE( vv_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    2035                    ENDIF
    2036                    IF ( k == 1 )  THEN
    2037                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    2038                                                     nxl_on_file:nxr_on_file) )
    2039                       READ ( 13 )  tmp_3d_non_standard
    2040                    ENDIF
    2041                    vv_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    2042 
    2043                 CASE ( 'v_m_l' )
    2044                    IF ( k == 1 )  THEN
    2045                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    2046                                                     0:1) )
    2047                       READ ( 13 )  tmp_3d_non_standard
    2048                    ENDIF
    2049                    IF ( bc_radiation_l )  THEN
    2050                       v_m_l(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    2051                    ENDIF
    2052 
    2053                 CASE ( 'v_m_n' )
    2054                    IF ( k == 1 )  THEN
    2055                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
    2056                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    2057                       READ ( 13 )  tmp_3d_non_standard
    2058                    ENDIF
    2059                    IF ( bc_radiation_n )  THEN
    2060                       v_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    2061                    ENDIF
    2062 
    2063                 CASE ( 'v_m_r' )
    2064                    IF ( k == 1 )  THEN
    2065                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    2066                                                     nx-1:nx) )
    2067                       READ ( 13 )  tmp_3d_non_standard
    2068                    ENDIF
    2069                    IF ( bc_radiation_r )  THEN
    2070                       v_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    2071                    ENDIF
    2072 
    2073                 CASE ( 'v_m_s' )
    2074                    IF ( k == 1 )  THEN
    2075                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,1:2,                                 &
    2076                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    2077                       READ ( 13 )  tmp_3d_non_standard
    2078                    ENDIF
    2079                    IF ( bc_radiation_s )  THEN
    2080                       v_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    2081                    ENDIF
    2082 
    2083                 CASE ( 'vpt' )
    2084                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2085                    vpt(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                &
    2086                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2087 
    2088                 CASE ( 'vpt_av' )
    2089                    IF ( .NOT. ALLOCATED( vpt_av ) )  THEN
    2090                       ALLOCATE( vpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    2091                    ENDIF
    2092                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2093                    vpt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
    2094                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2095 
    2096                 CASE ( 'w' )
    2097                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2098                    w(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
    2099                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2100 
    2101                 CASE ( 'w_av' )
    2102                    IF ( .NOT. ALLOCATED( w_av ) )  THEN
    2103                       ALLOCATE( w_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
    2104                    ENDIF
    2105                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    2106                    w_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
    2107                       tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2108 
    2109                 CASE ( 'ww_av' )
    2110                    IF ( .NOT. ALLOCATED( ww_av ) )  THEN
    2111                       ALLOCATE( ww_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    2112                    ENDIF
    2113                    IF ( k == 1 )  THEN
    2114                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    2115                                                     nxl_on_file:nxr_on_file) )
    2116                       READ ( 13 )  tmp_3d_non_standard
    2117                    ENDIF
    2118                    ww_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    2119 
    2120                 CASE ( 'w_m_l' )
    2121                    IF ( k == 1 )  THEN
    2122                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    2123                                                     0:1) )
    2124                       READ ( 13 )  tmp_3d_non_standard
    2125                    ENDIF
    2126                    IF ( bc_radiation_l )  THEN
    2127                       w_m_l(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    2128                    ENDIF
    2129 
    2130                 CASE ( 'w_m_n' )
    2131                    IF ( k == 1 )  THEN
    2132                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
    2133                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    2134                       READ ( 13 )  tmp_3d_non_standard
    2135                    ENDIF
    2136                    IF ( bc_radiation_n )  THEN
    2137                       w_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    2138                    ENDIF
    2139 
    2140                 CASE ( 'w_m_r' )
    2141                    IF ( k == 1 )  THEN
    2142                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
    2143                                                     nx-1:nx) )
    2144                       READ ( 13 )  tmp_3d_non_standard
    2145                    ENDIF
    2146                    IF ( bc_radiation_r )  THEN
    2147                       w_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
    2148                    ENDIF
    2149 
    2150                 CASE ( 'w_m_s' )
    2151                    IF ( k == 1 )  THEN
    2152                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,0:1,                                 &
    2153                                                     nxl_on_file-nbgp:nxr_on_file+nbgp) )
    2154                       READ ( 13 )  tmp_3d_non_standard
    2155                    ENDIF
    2156                    IF ( bc_radiation_s )  THEN
    2157                       w_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
    2158                    ENDIF
    2159 
    2160                 CASE ( 'wspeed_av' )
    2161                    IF ( .NOT. ALLOCATED( wspeed_av ) )  THEN
    2162                       ALLOCATE( wspeed_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
    2163                    ENDIF
    2164                    IF ( k == 1 )  THEN
    2165                       ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
    2166                                                     nxl_on_file:nxr_on_file) )
    2167                       READ ( 13 )  tmp_3d_non_standard
    2168                    ENDIF
    2169                    wspeed_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
    2170 
    2171                 CASE ( 'z0_av' )
    2172                    IF ( .NOT. ALLOCATED( z0_av ) )  THEN
    2173                       ALLOCATE( z0_av(nysg:nyng,nxlg:nxrg) )
    2174                    ENDIF
    2175                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    2176                    z0_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
    2177                       tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2178 
    2179                 CASE ( 'z0h_av' )
    2180                    IF ( .NOT. ALLOCATED( z0h_av ) )  THEN
    2181                       ALLOCATE( z0h_av(nysg:nyng,nxlg:nxrg) )
    2182                    ENDIF
    2183                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    2184                    z0h_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
    2185                        tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2186 
    2187                 CASE ( 'z0q_av' )
    2188                    IF ( .NOT. ALLOCATED( z0q_av ) )  THEN
    2189                       ALLOCATE( z0q_av(nysg:nyng,nxlg:nxrg) )
    2190                    ENDIF
    2191                    IF ( k == 1 )  READ ( 13 )  tmp_2d
    2192                    z0q_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
    2193                        tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
    2194 
    2195                 CASE DEFAULT
    2196 
    2197 !
    2198 !--                Read restart data of surfaces
    2199                    IF ( .NOT. found )  CALL surface_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf,   &
    2200                                                                nxr_on_file, nynf, nyn_on_file,     &
    2201                                                                nysf, nysc, nys_on_file, found )
    2202 !
    2203 !--                Read restart data of other modules
    2204                    IF ( .NOT. found ) CALL module_interface_rrd_local(                             &
    2205                                                                k, nxlf, nxlc, nxl_on_file, nxrf,   &
    2206                                                                nxrc, nxr_on_file, nynf, nync,      &
    2207                                                                nyn_on_file, nysf, nysc,            &
    2208                                                                nys_on_file, tmp_2d, tmp_3d, found )
    2209 
    2210 
    2211                    IF ( .NOT. found )  THEN
    2212                       WRITE( message_string, * ) 'unknown variable named "',                       &
    2213                                                  restart_string(1:length),                         &
    2214                                                 '" found in subdomain data ',                      &
    2215                                                 'from prior run on PE ', myid
    2216                       CALL message( 'rrd_local', 'PA0302', 1, 2, 0, 6, 0 )
    2217 
    2218                    ENDIF
    2219 
    2220              END SELECT
    2221 
    2222           ENDDO ! overlaploop
    2223 
    2224 !
    2225 !--       Deallocate non standard array needed for specific variables only
    2226           IF ( ALLOCATED( tmp_3d_non_standard ) )  DEALLOCATE( tmp_3d_non_standard )
    2227 
    2228 !
    2229 !--       Read next character string
     1551       ENDIF
     1552
     1553!
     1554!--    Read data from all restart files determined above
     1555       DO  i = 1, files_to_be_opened
     1556
     1557          j = file_list(i)
     1558!
     1559!--       Set the filename (underscore followed by four digit processor id)
     1560          WRITE (myid_char,'(''_'',I6.6)')  j
     1561
     1562!
     1563!--       Open the restart file. If this file has been created by PE0 (_000000),
     1564!--       the global variables at the beginning of the file have to be skipped
     1565!--       first.
     1566          CALL check_open( 13 )
     1567          IF ( j == 0 )  CALL rrd_skip_global
     1568
     1569!
     1570!--       First compare the version numbers
    22301571          READ ( 13 )  length
    22311572          READ ( 13 )  restart_string(1:length)
    2232 
    2233        ENDDO ! dataloop
    2234 !
    2235 !--    Close the restart file
    2236        CALL close_file( 13 )
    2237 
    2238        DEALLOCATE( tmp_2d, tmp_3d )
    2239 
    2240     ENDDO  ! loop over restart files
    2241 !
    2242 !-- Deallocate temporary buffer arrays
    2243     DEALLOCATE( nxlfa )
    2244     DEALLOCATE( nxrfa )
    2245     DEALLOCATE( nynfa )
    2246     DEALLOCATE( nysfa )
    2247     DEALLOCATE( offset_xa )
    2248     DEALLOCATE( offset_ya )
    2249 !
    2250 !-- Restore the original filename for the restart file to be written
    2251     myid_char = myid_char_save
     1573          READ ( 13 )  version_on_file
     1574
     1575          binary_version_local = '4.7'
     1576          IF ( TRIM( version_on_file ) /= TRIM( binary_version_local ) )  THEN
     1577             WRITE( message_string, * ) 'version mismatch concerning ',                               &
     1578                                        'binary_version_local:',                                      &
     1579                                        '&version on file    = "', TRIM( version_on_file ), '"',      &
     1580                                        '&version in program = "', TRIM( binary_version_local ), '"'
     1581             CALL message( 'rrd_local', 'PA0286', 1, 2, 0, 6, 0 )
     1582          ENDIF
     1583
     1584!
     1585!--       Read number of processors, processor-id, and array ranges.
     1586!--       Compare the array ranges with those stored in the index bound array.
     1587          READ ( 13 )  numprocs_on_file, myid_on_file, nxl_on_file, nxr_on_file, nys_on_file,         &
     1588                       nyn_on_file, nzb_on_file, nzt_on_file
     1589
     1590          IF ( nxl_on_file /= hor_index_bounds_previous_run(1,j) )  THEN
     1591             WRITE( message_string, * ) 'problem with index bound nxl on ',                           &
     1592                                        'restart file "', myid_char, '"',                             &
     1593                                        '&nxl = ', nxl_on_file, ' but it should be',                  &
     1594                                        '&= ', hor_index_bounds_previous_run(1,j),                    &
     1595                                        '&from the index bound information array'
     1596             CALL message( 'rrd_local', 'PA0287', 2, 2, -1, 6, 1 )
     1597          ENDIF
     1598
     1599          IF ( nxr_on_file /= hor_index_bounds_previous_run(2,j) )  THEN
     1600              WRITE( message_string, * ) 'problem with index bound nxr on ',                          &
     1601                                         'restart file "', myid_char, '"'  ,                          &
     1602                                         ' nxr = ', nxr_on_file, ' but it should be',                 &
     1603                                         ' = ', hor_index_bounds_previous_run(2,j),                   &
     1604                                         ' from the index bound information array'
     1605             CALL message( 'rrd_local', 'PA0288', 2, 2, -1, 6, 1 )
     1606
     1607          ENDIF
     1608
     1609          IF ( nys_on_file /= hor_index_bounds_previous_run(3,j) )  THEN
     1610             WRITE( message_string, * ) 'problem with index bound nys on ',                           &
     1611                                        'restart file "', myid_char, '"',                             &
     1612                                        '&nys = ', nys_on_file, ' but it should be',                  &
     1613                                        '&= ', hor_index_bounds_previous_run(3,j),                    &
     1614                                        '&from the index bound information array'
     1615             CALL message( 'rrd_local', 'PA0289', 2, 2, -1, 6, 1 )
     1616          ENDIF
     1617
     1618          IF ( nyn_on_file /= hor_index_bounds_previous_run(4,j) )  THEN
     1619             WRITE( message_string, * ) 'problem with index bound nyn on ',                           &
     1620                                        'restart file "', myid_char, '"',                             &
     1621                                        '&nyn = ', nyn_on_file, ' but it should be',                  &
     1622                                        '&= ', hor_index_bounds_previous_run(4,j),                    &
     1623                                        '&from the index bound information array'
     1624             CALL message( 'rrd_local', 'PA0290', 2, 2, -1, 6, 1 )
     1625          ENDIF
     1626
     1627          IF ( nzb_on_file /= nzb )  THEN
     1628             WRITE( message_string, * ) 'mismatch between actual data and data ',                     &
     1629                                        'from prior run on PE ', myid,                                &
     1630                                        '&nzb on file = ', nzb_on_file,                               &
     1631                                        '&nzb         = ', nzb
     1632             CALL message( 'rrd_local', 'PA0291', 1, 2, 0, 6, 0 )
     1633          ENDIF
     1634
     1635          IF ( nzt_on_file /= nzt )  THEN
     1636             WRITE( message_string, * ) 'mismatch between actual data and data ',                     &
     1637                                        'from prior run on PE ', myid,                                &
     1638                                        '&nzt on file = ', nzt_on_file,                               &
     1639                                        '&nzt         = ', nzt
     1640             CALL message( 'rrd_local', 'PA0292', 1, 2, 0, 6, 0 )
     1641          ENDIF
     1642
     1643!
     1644!--       Allocate temporary arrays sized as the arrays on the restart file
     1645          ALLOCATE( tmp_2d(nys_on_file-nbgp:nyn_on_file+nbgp,nxl_on_file-nbgp:nxr_on_file+nbgp),      &
     1646                    tmp_3d(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,                               &
     1647                           nxl_on_file-nbgp:nxr_on_file+nbgp) )
     1648
     1649!
     1650!--       Read arrays
     1651!--       ATTENTION: If the following read commands have been altered, the
     1652!--       ---------- version number of the variable binary_version_local must
     1653!--                  be altered, too. Furthermore, the output list of arrays in
     1654!--                  wrd_write_local must also be altered
     1655!--                  accordingly.
     1656          READ ( 13 )  length
     1657          READ ( 13 )  restart_string(1:length)
     1658
     1659
     1660!
     1661!--       Loop over processor specific field data
     1662          DO  WHILE ( restart_string(1:length) /= '*** end ***' )
     1663
     1664!
     1665!--          Map data on file as often as needed (data are read only for k=1)
     1666             DO  k = 1, overlap_count(i)
     1667
     1668                found = .FALSE.
     1669
     1670!
     1671!--             Get the index range of the subdomain on file which overlap with
     1672!--             the current subdomain
     1673                nxlf = nxlfa(i,k)
     1674                nxlc = nxlfa(i,k) + offset_xa(i,k)
     1675                nxrf = nxrfa(i,k)
     1676                nxrc = nxrfa(i,k) + offset_xa(i,k)
     1677                nysf = nysfa(i,k)
     1678                nysc = nysfa(i,k) + offset_ya(i,k)
     1679                nynf = nynfa(i,k)
     1680                nync = nynfa(i,k) + offset_ya(i,k)
     1681
     1682
     1683                SELECT CASE ( restart_string(1:length) )
     1684
     1685                   CASE ( 'ghf_av' )
     1686                      IF ( .NOT. ALLOCATED( ghf_av ) )  THEN
     1687                         ALLOCATE( ghf_av(nysg:nyng,nxlg:nxrg) )
     1688                      ENDIF
     1689                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1690                      ghf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1691                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1692
     1693                   CASE ( 'e' )
     1694                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1695                      e(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     1696                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1697
     1698                   CASE ( 'e_av' )
     1699                      IF ( .NOT. ALLOCATED( e_av ) )  THEN
     1700                         ALLOCATE( e_av(nzb:nzt+1,nys-nbgp:nyn+nbgp,                                  &
     1701                                        nxl-nbgp:nxr+nbgp) )
     1702                      ENDIF
     1703                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1704                      e_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1705                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1706
     1707                   CASE ( 'kh' )
     1708                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1709                      kh(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
     1710                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1711
     1712                   CASE ( 'kh_av' )
     1713                      IF ( .NOT. ALLOCATED( kh_av ) )  THEN
     1714                         ALLOCATE( kh_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
     1715                      ENDIF
     1716                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1717                      kh_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
     1718                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1719
     1720                   CASE ( 'km' )
     1721                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1722                      km(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
     1723                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1724
     1725                   CASE ( 'km_av' )
     1726                      IF ( .NOT. ALLOCATED( km_av ) )  THEN
     1727                         ALLOCATE( km_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
     1728                      ENDIF
     1729                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1730                      km_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
     1731                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1732
     1733                   CASE ( 'lpt_av' )
     1734                      IF ( .NOT. ALLOCATED( lpt_av ) )  THEN
     1735                         ALLOCATE( lpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
     1736                      ENDIF
     1737                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1738                      lpt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
     1739                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1740
     1741                   CASE ( 'lwp_av' )
     1742                      IF ( .NOT. ALLOCATED( lwp_av ) )  THEN
     1743                         ALLOCATE( lwp_av(nysg:nyng,nxlg:nxrg) )
     1744                      ENDIF
     1745                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1746                      lwp_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1747                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1748
     1749                   CASE ( 'p' )
     1750                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1751                      p(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     1752                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1753
     1754                   CASE ( 'p_av' )
     1755                      IF ( .NOT. ALLOCATED( p_av ) )  THEN
     1756                         ALLOCATE( p_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1757                      ENDIF
     1758                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1759                      p_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1760                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1761
     1762                   CASE ( 'pt' )
     1763                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1764                      pt(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
     1765                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1766
     1767                   CASE ( 'pt_av' )
     1768                      IF ( .NOT. ALLOCATED( pt_av ) )  THEN
     1769                         ALLOCATE( pt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1770                      ENDIF
     1771                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1772                      pt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
     1773                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1774
     1775                   CASE ( 'pt_2m_av' )
     1776                      IF ( .NOT. ALLOCATED( pt_2m_av ) )  THEN
     1777                         ALLOCATE( pt_2m_av(nysg:nyng,nxlg:nxrg) )
     1778                      ENDIF
     1779                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1780                      pt_2m_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                            &
     1781                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1782
     1783                   CASE ( 'q' )
     1784                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1785                      q(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     1786                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1787
     1788                   CASE ( 'q_av' )
     1789                      IF ( .NOT. ALLOCATED( q_av ) )  THEN
     1790                         ALLOCATE( q_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg ))
     1791                      ENDIF
     1792                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1793                      q_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1794                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1795
     1796                   CASE ( 'ql' )
     1797                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1798                      ql(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                 &
     1799                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1800
     1801                   CASE ( 'ql_av' )
     1802                      IF ( .NOT. ALLOCATED( ql_av ) )  THEN
     1803                         ALLOCATE( ql_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1804                      ENDIF
     1805                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1806                      ql_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
     1807                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1808
     1809                   CASE ( 'qsurf_av' )
     1810                      IF ( .NOT. ALLOCATED( qsurf_av ) )  THEN
     1811                         ALLOCATE( qsurf_av(nysg:nyng,nxlg:nxrg) )
     1812                      ENDIF
     1813                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1814                      qsurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
     1815                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1816
     1817                   CASE ( 'qsws_av' )
     1818                      IF ( .NOT. ALLOCATED( qsws_av ) )  THEN
     1819                         ALLOCATE( qsws_av(nysg:nyng,nxlg:nxrg) )
     1820                      ENDIF
     1821                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1822                      qsws_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                             &
     1823                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1824
     1825                   CASE ( 'qv_av' )
     1826                      IF ( .NOT. ALLOCATED( qv_av ) )  THEN
     1827                         ALLOCATE( qv_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1828                      ENDIF
     1829                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1830                      qv_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                              &
     1831                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1832
     1833                   CASE ( 'r_a_av' )
     1834                      IF ( .NOT. ALLOCATED( r_a_av ) )  THEN
     1835                         ALLOCATE( r_a_av(nysg:nyng,nxlg:nxrg) )
     1836                      ENDIF
     1837                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1838                      r_a_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1839                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1840
     1841                   CASE ( 'random_iv' )  ! still unresolved issue
     1842                      IF ( k == 1 )  READ ( 13 )  random_iv
     1843                      IF ( k == 1 )  READ ( 13 )  random_iy
     1844
     1845                   CASE ( 'seq_random_array' )
     1846                      ALLOCATE( tmp_2d_id_random(nys_on_file:nyn_on_file,nxl_on_file:nxr_on_file) )
     1847                      ALLOCATE( tmp_2d_seq_random(5,nys_on_file:nyn_on_file,nxl_on_file:nxr_on_file) )
     1848                      IF ( .NOT. ALLOCATED( id_random_array ) )  THEN
     1849                         ALLOCATE( id_random_array(nys:nyn,nxl:nxr) )
     1850                      ENDIF
     1851                      IF ( .NOT. ALLOCATED( seq_random_array ) )  THEN
     1852                         ALLOCATE( seq_random_array(5,nys:nyn,nxl:nxr) )
     1853                      ENDIF
     1854                      IF ( k == 1 )  READ ( 13 )  tmp_2d_id_random
     1855                      IF ( k == 1 )  READ ( 13 )  tmp_2d_seq_random
     1856                      id_random_array(nysc:nync,nxlc:nxrc) = tmp_2d_id_random(nysf:nynf,nxlf:nxrf)
     1857                      seq_random_array(:,nysc:nync,nxlc:nxrc) = tmp_2d_seq_random(:,nysf:nynf,nxlf:nxrf)
     1858                      DEALLOCATE( tmp_2d_id_random, tmp_2d_seq_random )
     1859
     1860                   CASE ( 's' )
     1861                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1862                      s(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     1863                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1864
     1865                   CASE ( 's_av' )
     1866                      IF ( .NOT. ALLOCATED( s_av ) )  THEN
     1867                         ALLOCATE( s_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg))
     1868                      ENDIF
     1869                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1870                      s_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1871                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1872
     1873                   CASE ( 'shf_av' )
     1874                      IF ( .NOT. ALLOCATED( shf_av ) )  THEN
     1875                         ALLOCATE( shf_av(nysg:nyng,nxlg:nxrg) )
     1876                      ENDIF
     1877                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1878                      shf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
     1879                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1880
     1881                   CASE ( 'ssurf_av' )
     1882                      IF ( .NOT. ALLOCATED( ssurf_av ) )  THEN
     1883                         ALLOCATE( ssurf_av(nysg:nyng,nxlg:nxrg) )
     1884                      ENDIF
     1885                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1886                      ssurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
     1887                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1888
     1889                   CASE ( 'ssws_av' )
     1890                      IF ( .NOT. ALLOCATED( ssws_av ) )  THEN
     1891                         ALLOCATE( ssws_av(nysg:nyng,nxlg:nxrg) )
     1892                      ENDIF
     1893                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1894                      ssws_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                             &
     1895                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1896
     1897                   CASE ( 'ti_av' )
     1898                      IF ( .NOT. ALLOCATED( ti_av ) )  THEN
     1899                         ALLOCATE( ti_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     1900                      ENDIF
     1901                      IF ( k == 1 )  THEN
     1902                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     1903                                                       nxl_on_file:nxr_on_file) )
     1904                         READ ( 13 )  tmp_3d_non_standard
     1905                      ENDIF
     1906                      ti_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     1907
     1908                   CASE ( 'ts_av' )
     1909                      IF ( .NOT. ALLOCATED( ts_av ) )  THEN
     1910                         ALLOCATE( ts_av(nysg:nyng,nxlg:nxrg) )
     1911                      ENDIF
     1912                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1913                      ts_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
     1914                           tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1915
     1916                   CASE ( 'tsurf_av' )
     1917                      IF ( .NOT. ALLOCATED( tsurf_av ) )  THEN
     1918                         ALLOCATE( tsurf_av(nysg:nyng,nxlg:nxrg) )
     1919                      ENDIF
     1920                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1921                      tsurf_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
     1922                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1923
     1924                   CASE ( 'u' )
     1925                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1926                      u(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     1927                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1928
     1929                   CASE ( 'u_av' )
     1930                      IF ( .NOT. ALLOCATED( u_av ) )  THEN
     1931                         ALLOCATE( u_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     1932                      ENDIF
     1933                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     1934                      u_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     1935                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1936
     1937                   CASE ( 'u_center_av' )
     1938                      IF ( .NOT. ALLOCATED( u_center_av ) )  THEN
     1939                         ALLOCATE( u_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     1940                      ENDIF
     1941                      IF ( k == 1 )  THEN
     1942                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     1943                                                       nxl_on_file:nxr_on_file) )
     1944                         READ ( 13 )  tmp_3d_non_standard
     1945                      ENDIF
     1946                      u_center_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     1947
     1948                   CASE ( 'uu_av' )
     1949                      IF ( .NOT. ALLOCATED( uu_av ) )  THEN
     1950                         ALLOCATE( uu_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     1951                      ENDIF
     1952                      IF ( k == 1 )  THEN
     1953                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     1954                                                       nxl_on_file:nxr_on_file) )
     1955                         READ ( 13 )  tmp_3d_non_standard
     1956                      ENDIF
     1957                      uu_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     1958
     1959                   CASE ( 'uv_10m_av' )
     1960                      IF ( .NOT. ALLOCATED( uv_10m_av ) )  THEN
     1961                         ALLOCATE( uv_10m_av(nysg:nyng,nxlg:nxrg) )
     1962                      ENDIF
     1963                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     1964                      uv_10m_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                           &
     1965                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     1966
     1967                   CASE ( 'u_m_l' )
     1968                      IF ( k == 1 )  THEN
     1969                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     1970                                                       1:2) )
     1971                         READ ( 13 )  tmp_3d_non_standard
     1972                      ENDIF
     1973                      IF ( bc_radiation_l )  THEN
     1974                         u_m_l(:,nysc-nbgp:nync+nbgp,:) =  tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     1975                      ENDIF
     1976
     1977                   CASE ( 'u_m_n' )
     1978                      IF ( k == 1 )  THEN
     1979                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
     1980                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     1981                         READ ( 13 )  tmp_3d_non_standard
     1982                      ENDIF
     1983                      IF ( bc_radiation_n )  THEN
     1984                         u_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     1985                      ENDIF
     1986
     1987                   CASE ( 'u_m_r' )
     1988                      IF ( k == 1 )  THEN
     1989                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     1990                                                       nx-1:nx) )
     1991                         READ ( 13 )  tmp_3d_non_standard
     1992                      ENDIF
     1993                      IF ( bc_radiation_r )  THEN
     1994                         u_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     1995                      ENDIF
     1996
     1997                   CASE ( 'u_m_s' )
     1998                      IF ( k == 1 )  THEN
     1999                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,0:1,                                 &
     2000                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     2001                         READ ( 13 )  tmp_3d_non_standard
     2002                      ENDIF
     2003                      IF ( bc_radiation_s )  THEN
     2004                         u_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     2005                      ENDIF
     2006
     2007                   CASE ( 'us_av' )
     2008                      IF ( .NOT. ALLOCATED( us_av ) )  THEN
     2009                         ALLOCATE( us_av(nysg:nyng,nxlg:nxrg) )
     2010                      ENDIF
     2011                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     2012                      us_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
     2013                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2014
     2015                   CASE ( 'v' )
     2016                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2017                      v(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     2018                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2019
     2020                   CASE ( 'v_av' )
     2021                      IF ( .NOT. ALLOCATED( v_av ) )  THEN
     2022                         ALLOCATE( v_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2023                      ENDIF
     2024                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2025                      v_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     2026                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2027
     2028                   CASE ( 'v_center_av' )
     2029                      IF ( .NOT. ALLOCATED( v_center_av ) )  THEN
     2030                         ALLOCATE( v_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2031                      ENDIF
     2032                      IF ( k == 1 )  THEN
     2033                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     2034                                                       nxl_on_file:nxr_on_file) )
     2035                         READ ( 13 )  tmp_3d_non_standard
     2036                      ENDIF
     2037                      v_center_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     2038
     2039                   CASE ( 'vv_av' )
     2040                      IF ( .NOT. ALLOCATED( vv_av ) )  THEN
     2041                      ALLOCATE( vv_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2042                      ENDIF
     2043                      IF ( k == 1 )  THEN
     2044                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     2045                                                       nxl_on_file:nxr_on_file) )
     2046                         READ ( 13 )  tmp_3d_non_standard
     2047                      ENDIF
     2048                      vv_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     2049
     2050                   CASE ( 'v_m_l' )
     2051                      IF ( k == 1 )  THEN
     2052                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     2053                                                       0:1) )
     2054                         READ ( 13 )  tmp_3d_non_standard
     2055                      ENDIF
     2056                      IF ( bc_radiation_l )  THEN
     2057                         v_m_l(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     2058                      ENDIF
     2059
     2060                   CASE ( 'v_m_n' )
     2061                      IF ( k == 1 )  THEN
     2062                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
     2063                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     2064                         READ ( 13 )  tmp_3d_non_standard
     2065                      ENDIF
     2066                      IF ( bc_radiation_n )  THEN
     2067                         v_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     2068                      ENDIF
     2069
     2070                   CASE ( 'v_m_r' )
     2071                      IF ( k == 1 )  THEN
     2072                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     2073                                                       nx-1:nx) )
     2074                         READ ( 13 )  tmp_3d_non_standard
     2075                      ENDIF
     2076                      IF ( bc_radiation_r )  THEN
     2077                         v_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     2078                      ENDIF
     2079
     2080                   CASE ( 'v_m_s' )
     2081                      IF ( k == 1 )  THEN
     2082                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,1:2,                                 &
     2083                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     2084                         READ ( 13 )  tmp_3d_non_standard
     2085                      ENDIF
     2086                      IF ( bc_radiation_s )  THEN
     2087                         v_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     2088                      ENDIF
     2089
     2090                   CASE ( 'vpt' )
     2091                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2092                      vpt(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                &
     2093                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2094
     2095                   CASE ( 'vpt_av' )
     2096                      IF ( .NOT. ALLOCATED( vpt_av ) )  THEN
     2097                         ALLOCATE( vpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2098                      ENDIF
     2099                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2100                      vpt_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                             &
     2101                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2102
     2103                   CASE ( 'w' )
     2104                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2105                      w(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                                  &
     2106                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2107
     2108                   CASE ( 'w_av' )
     2109                      IF ( .NOT. ALLOCATED( w_av ) )  THEN
     2110                         ALLOCATE( w_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2111                      ENDIF
     2112                      IF ( k == 1 )  READ ( 13 )  tmp_3d
     2113                      w_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =                               &
     2114                         tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2115
     2116                   CASE ( 'ww_av' )
     2117                      IF ( .NOT. ALLOCATED( ww_av ) )  THEN
     2118                         ALLOCATE( ww_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2119                      ENDIF
     2120                      IF ( k == 1 )  THEN
     2121                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     2122                                                       nxl_on_file:nxr_on_file) )
     2123                         READ ( 13 )  tmp_3d_non_standard
     2124                      ENDIF
     2125                      ww_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     2126
     2127                   CASE ( 'w_m_l' )
     2128                      IF ( k == 1 )  THEN
     2129                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     2130                                                       0:1) )
     2131                         READ ( 13 )  tmp_3d_non_standard
     2132                      ENDIF
     2133                      IF ( bc_radiation_l )  THEN
     2134                         w_m_l(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     2135                      ENDIF
     2136
     2137                   CASE ( 'w_m_n' )
     2138                      IF ( k == 1 )  THEN
     2139                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,ny-1:ny,                             &
     2140                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     2141                         READ ( 13 )  tmp_3d_non_standard
     2142                      ENDIF
     2143                      IF ( bc_radiation_n )  THEN
     2144                         w_m_n(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     2145                      ENDIF
     2146
     2147                   CASE ( 'w_m_r' )
     2148                      IF ( k == 1 )  THEN
     2149                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file-nbgp:nyn_on_file+nbgp,   &
     2150                                                       nx-1:nx) )
     2151                         READ ( 13 )  tmp_3d_non_standard
     2152                      ENDIF
     2153                      IF ( bc_radiation_r )  THEN
     2154                         w_m_r(:,nysc-nbgp:nync+nbgp,:) = tmp_3d_non_standard(:,nysf-nbgp:nynf+nbgp,:)
     2155                      ENDIF
     2156
     2157                   CASE ( 'w_m_s' )
     2158                      IF ( k == 1 )  THEN
     2159                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,0:1,                                 &
     2160                                                       nxl_on_file-nbgp:nxr_on_file+nbgp) )
     2161                         READ ( 13 )  tmp_3d_non_standard
     2162                      ENDIF
     2163                      IF ( bc_radiation_s )  THEN
     2164                         w_m_s(:,:,nxlc-nbgp:nxrc+nbgp) = tmp_3d_non_standard(:,:,nxlf-nbgp:nxrf+nbgp)
     2165                      ENDIF
     2166
     2167                   CASE ( 'wspeed_av' )
     2168                      IF ( .NOT. ALLOCATED( wspeed_av ) )  THEN
     2169                         ALLOCATE( wspeed_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2170                      ENDIF
     2171                      IF ( k == 1 )  THEN
     2172                         ALLOCATE( tmp_3d_non_standard(nzb:nzt+1,nys_on_file:nyn_on_file,             &
     2173                                                       nxl_on_file:nxr_on_file) )
     2174                         READ ( 13 )  tmp_3d_non_standard
     2175                      ENDIF
     2176                      wspeed_av(:,nysc:nync,nxlc:nxrc) = tmp_3d_non_standard(:,nysf:nynf,nxlf:nxrf)
     2177
     2178                   CASE ( 'z0_av' )
     2179                      IF ( .NOT. ALLOCATED( z0_av ) )  THEN
     2180                         ALLOCATE( z0_av(nysg:nyng,nxlg:nxrg) )
     2181                      ENDIF
     2182                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     2183                      z0_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                               &
     2184                         tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2185
     2186                   CASE ( 'z0h_av' )
     2187                      IF ( .NOT. ALLOCATED( z0h_av ) )  THEN
     2188                         ALLOCATE( z0h_av(nysg:nyng,nxlg:nxrg) )
     2189                      ENDIF
     2190                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     2191                      z0h_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
     2192                          tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2193
     2194                   CASE ( 'z0q_av' )
     2195                      IF ( .NOT. ALLOCATED( z0q_av ) )  THEN
     2196                         ALLOCATE( z0q_av(nysg:nyng,nxlg:nxrg) )
     2197                      ENDIF
     2198                      IF ( k == 1 )  READ ( 13 )  tmp_2d
     2199                      z0q_av(nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp)  =                              &
     2200                      tmp_2d(nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     2201
     2202                   CASE DEFAULT
     2203
     2204!
     2205!--                   Read restart data of surfaces
     2206                      IF ( .NOT. found )  CALL surface_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf,   &
     2207                                                                  nxr_on_file, nynf, nyn_on_file,     &
     2208                                                                  nysf, nysc, nys_on_file, found )
     2209!
     2210!--                   Read restart data of other modules
     2211                      IF ( .NOT. found ) CALL module_interface_rrd_local(                             &
     2212                                                                  k, nxlf, nxlc, nxl_on_file, nxrf,   &
     2213                                                                  nxrc, nxr_on_file, nynf, nync,      &
     2214                                                                  nyn_on_file, nysf, nysc,            &
     2215                                                                  nys_on_file, tmp_2d, tmp_3d, found )
     2216
     2217
     2218                      IF ( .NOT. found )  THEN
     2219                         WRITE( message_string, * ) 'unknown variable named "',                       &
     2220                                                    restart_string(1:length),                         &
     2221                                                   '" found in subdomain data ',                      &
     2222                                                   'from prior run on PE ', myid
     2223                         CALL message( 'rrd_local', 'PA0302', 1, 2, 0, 6, 0 )
     2224
     2225                      ENDIF
     2226
     2227                END SELECT
     2228
     2229             ENDDO ! overlaploop
     2230
     2231!
     2232!--          Deallocate non standard array needed for specific variables only
     2233             IF ( ALLOCATED( tmp_3d_non_standard ) )  DEALLOCATE( tmp_3d_non_standard )
     2234
     2235!
     2236!--          Read next character string
     2237             READ ( 13 )  length
     2238             READ ( 13 )  restart_string(1:length)
     2239
     2240          ENDDO ! dataloop
     2241!
     2242!--       Close the restart file
     2243          CALL close_file( 13 )
     2244
     2245          DEALLOCATE( tmp_2d, tmp_3d )
     2246
     2247       ENDDO  ! loop over restart files
     2248!
     2249!--    Deallocate temporary buffer arrays
     2250       DEALLOCATE( nxlfa )
     2251       DEALLOCATE( nxrfa )
     2252       DEALLOCATE( nynfa )
     2253       DEALLOCATE( nysfa )
     2254       DEALLOCATE( offset_xa )
     2255       DEALLOCATE( offset_ya )
     2256!
     2257!--    Restore the original filename for the restart file to be written
     2258       myid_char = myid_char_save
     2259
     2260
     2261    ELSEIF ( TRIM( restart_data_format_input ) == 'mpi' )  THEN
     2262
     2263!
     2264!--    Read global restart data using MPI-IO
     2265!
     2266!--    Open the MPI-IO restart file.
     2267       CALL rd_mpi_io_open( 'read', 'BININ' // TRIM( coupling_char ) )
     2268
     2269
     2270       CALL rd_mpi_io_check_array( 'ghf_av' , found = array_found )
     2271       IF ( array_found )  THEN
     2272          IF (.NOT. ALLOCATED( ghf_av ) )  ALLOCATE( ghf_av(nysg:nyng,nxlg:nxrg) )
     2273          CALL rrd_mpi_io( 'ghf_av', ghf_av )
     2274       ENDIF
     2275
     2276       CALL rrd_mpi_io( 'e', e )
     2277
     2278       CALL rd_mpi_io_check_array( 'e_av' , found = array_found )
     2279       IF ( array_found  )  THEN
     2280          IF ( .NOT. ALLOCATED( e_av ) )  ALLOCATE( e_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2281          CALL rrd_mpi_io( 'e_av', e_av )
     2282       ENDIF
     2283
     2284       CALL rrd_mpi_io( 'kh', kh )
     2285
     2286       CALL rd_mpi_io_check_array( 'kh_av' , found = array_found )
     2287       IF ( array_found )  THEN
     2288          IF ( .NOT. ALLOCATED( kh_av ) )  ALLOCATE( kh_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2289          CALL rrd_mpi_io( 'kh_av', kh_av )
     2290       ENDIF
     2291
     2292       CALL rrd_mpi_io( 'km' , km)
     2293
     2294       CALL rd_mpi_io_check_array( 'km_av' , found = array_found )
     2295       IF ( array_found )  THEN
     2296          IF ( .NOT. ALLOCATED( km_av ) )  ALLOCATE( km_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2297          CALL rrd_mpi_io( 'km_av', km_av )
     2298       ENDIF
     2299
     2300       CALL rd_mpi_io_check_array( 'lpt_av' , found = array_found )
     2301       IF ( array_found )  THEN
     2302          IF ( .NOT. ALLOCATED( lpt_av ) )  ALLOCATE( lpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2303          CALL rrd_mpi_io( 'lpt_av', lpt_av )
     2304       ENDIF
     2305
     2306       CALL rd_mpi_io_check_array( 'lwp_av' , found = array_found )
     2307       IF ( array_found )  THEN
     2308          IF ( .NOT. ALLOCATED( lwp_av ) )  ALLOCATE( lwp_av(nysg:nyng,nxlg:nxrg) )
     2309          CALL rrd_mpi_io( 'lwp_av', lwp_av )
     2310       ENDIF
     2311
     2312       CALL rrd_mpi_io( 'p', p)
     2313
     2314       CALL rd_mpi_io_check_array( 'p_av' , found = array_found )
     2315       IF ( array_found )  THEN
     2316          IF ( .NOT. ALLOCATED( p_av ) )  ALLOCATE( p_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2317          CALL rrd_mpi_io( 'p_av', p_av )
     2318       ENDIF
     2319
     2320       CALL rrd_mpi_io( 'pt', pt)
     2321
     2322       CALL rd_mpi_io_check_array( 'pt_av' , found = array_found )
     2323       IF ( array_found )  THEN
     2324          IF ( .NOT. ALLOCATED( pt_av ) )  ALLOCATE( pt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2325          CALL rrd_mpi_io( 'pt_av', pt_av )
     2326       ENDIF
     2327
     2328       CALL rd_mpi_io_check_array( 'pt_2m_av' , found = array_found )
     2329       IF ( array_found )  THEN
     2330          IF ( .NOT. ALLOCATED( pt_2m_av ) )  ALLOCATE( pt_2m_av(nysg:nyng,nxlg:nxrg) )
     2331          CALL rrd_mpi_io( 'pt_2m_av', pt_2m_av )
     2332       ENDIF
     2333
     2334       CALL rd_mpi_io_check_array( 'q' , found = array_found )
     2335       IF ( array_found )  THEN
     2336          CALL rrd_mpi_io( 'q', q )
     2337       ENDIF
     2338
     2339       CALL rd_mpi_io_check_array( 'q_av' , found = array_found )
     2340       IF ( array_found )  THEN
     2341          IF ( .NOT. ALLOCATED( q_av ) )  ALLOCATE( q_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2342          CALL rrd_mpi_io( 'q_av', q_av )
     2343       ENDIF
     2344
     2345       CALL rd_mpi_io_check_array( 'ql' , found = array_found )
     2346       IF ( array_found )  THEN
     2347          CALL rrd_mpi_io( 'ql', ql )
     2348       ENDIF
     2349
     2350       CALL rd_mpi_io_check_array( 'ql_av' , found = array_found )
     2351       IF ( array_found )  THEN
     2352          IF ( .NOT. ALLOCATED( ql_av ) )  ALLOCATE( ql_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2353          CALL rrd_mpi_io( 'ql_av', ql_av )
     2354       ENDIF
     2355
     2356       CALL rd_mpi_io_check_array( 'qsurf_av' , found = array_found )
     2357       IF ( array_found )  THEN
     2358          IF ( .NOT. ALLOCATED( qsurf_av ) )  ALLOCATE( qsurf_av(nysg:nyng,nxlg:nxrg) )
     2359          CALL rrd_mpi_io( 'qsurf_av', qsurf_av )
     2360       ENDIF
     2361
     2362       CALL rd_mpi_io_check_array( 'qsws_av' , found = array_found )
     2363       IF ( array_found )  THEN
     2364          IF ( .NOT. ALLOCATED( qsws_av ) )  ALLOCATE( qsws_av(nysg:nyng,nxlg:nxrg) )
     2365          CALL rrd_mpi_io( 'qsws_av', qsws_av )
     2366       ENDIF
     2367
     2368       CALL rd_mpi_io_check_array( 'qv_av' , found = array_found )
     2369       IF ( array_found )  THEN
     2370          IF ( .NOT. ALLOCATED( qv_av ) )  ALLOCATE( qv_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2371          CALL rrd_mpi_io( 'qv_av', qv_av )
     2372       ENDIF
     2373
     2374       CALL rd_mpi_io_check_array( 'r_a_av' , found = array_found )
     2375       IF ( array_found )  THEN
     2376          IF ( .NOT. ALLOCATED( r_a_av ) )  ALLOCATE( r_a_av(nysg:nyng,nxlg:nxrg) )
     2377          CALL rrd_mpi_io( 'r_a_av', r_a_av )
     2378       ENDIF
     2379
     2380!
     2381!--    ATTENTION: The random seeds are global data! If independent values for every PE are required,
     2382!--    the general approach of PE indendent restart will be lost. That means that in general the
     2383!--    parallel random number generator in random_generator_parallel_mod should be used!
     2384       CALL rrd_mpi_io_global_array( 'random_iv', random_iv )
     2385       CALL rrd_mpi_io( 'random_iy', random_iy )
     2386
     2387       CALL rd_mpi_io_check_array( 'id_random_array' , found = array_found )
     2388       IF ( array_found )  THEN
     2389          IF ( .NOT. ALLOCATED( id_random_array ) )  ALLOCATE( id_random_array(nys:nyn,nxl:nxr) )
     2390          IF ( .NOT. ALLOCATED( seq_random_array ) )  ALLOCATE( seq_random_array(5,nys:nyn,nxl:nxr) )
     2391          CALL rrd_mpi_io( 'id_random_array', id_random_array)
     2392          DO  i = 1, SIZE( seq_random_array, 1 )
     2393             WRITE( tmp_name, '(A,I2.2)' )  'seq_random_array', i
     2394             CALL rrd_mpi_io( TRIM(tmp_name), seq_random_array(i,:,:) )
     2395          ENDDO
     2396       ENDIF
     2397
     2398       CALL rd_mpi_io_check_array( 's' , found = array_found )
     2399       IF ( array_found )  THEN
     2400          CALL rrd_mpi_io( 's', s )
     2401       ENDIF
     2402
     2403       CALL rd_mpi_io_check_array( 's_av' , found = array_found )
     2404       IF ( array_found )  THEN
     2405          IF ( .NOT. ALLOCATED( s_av ) )  ALLOCATE( s_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2406          CALL rrd_mpi_io( 's_av', s_av )
     2407       ENDIF
     2408
     2409       CALL rd_mpi_io_check_array( 'shf_av' , found = array_found )
     2410       IF ( array_found )  THEN
     2411          IF ( .NOT. ALLOCATED( shf_av ) )  ALLOCATE( shf_av(nysg:nyng,nxlg:nxrg) )
     2412          CALL rrd_mpi_io( 'shf_av', shf_av )
     2413       ENDIF
     2414
     2415       CALL rd_mpi_io_check_array( 'ssurf_av' , found = array_found )
     2416       IF ( array_found )  THEN
     2417          IF ( .NOT. ALLOCATED( ssurf_av ) )  ALLOCATE( ssurf_av(nysg:nyng,nxlg:nxrg) )
     2418          CALL rrd_mpi_io( 'ssurf_av', ssurf_av )
     2419       ENDIF
     2420
     2421       CALL rd_mpi_io_check_array( 'ssws_av' , found = array_found )
     2422       IF ( array_found )  THEN
     2423          IF ( .NOT. ALLOCATED( ssws_av ) )  ALLOCATE( ssws_av(nysg:nyng,nxlg:nxrg) )
     2424          CALL rrd_mpi_io( 'ssws_av', ssws_av )
     2425       ENDIF
     2426
     2427       CALL rd_mpi_io_check_array( 'ti_av' , found = array_found )
     2428       IF ( array_found )  THEN
     2429          IF ( .NOT. ALLOCATED( ti_av ) )  ALLOCATE( ti_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2430          CALL rrd_mpi_io( 'ti_av', ti_av )
     2431       ENDIF
     2432
     2433       CALL rd_mpi_io_check_array( 'ts_av' , found = array_found )
     2434       IF ( array_found )  THEN
     2435          IF ( .NOT. ALLOCATED( ts_av ) )  ALLOCATE( ts_av(nysg:nyng,nxlg:nxrg) )
     2436          CALL rrd_mpi_io( 'ts_av', ts_av )
     2437       ENDIF
     2438
     2439       CALL rd_mpi_io_check_array( 'tsurf_av' , found = array_found )
     2440       IF ( array_found )  THEN
     2441          IF ( .NOT. ALLOCATED( tsurf_av ) )  ALLOCATE( tsurf_av(nysg:nyng,nxlg:nxrg) )
     2442          CALL rrd_mpi_io( 'tsurf_av', tsurf_av )
     2443       ENDIF
     2444
     2445       CALL rrd_mpi_io( 'u', u)
     2446
     2447       CALL rd_mpi_io_check_array( 'u_av' , found = array_found )
     2448       IF ( array_found )  THEN
     2449          IF ( .NOT. ALLOCATED( u_av ) )  ALLOCATE( u_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2450          CALL rrd_mpi_io( 'u_av', u_av )
     2451       ENDIF
     2452
     2453       CALL rd_mpi_io_check_array( 'u_center_av' , found = array_found )
     2454       IF ( array_found )  THEN
     2455          IF ( .NOT. ALLOCATED( u_center_av ) )  ALLOCATE( u_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2456          CALL rrd_mpi_io( 'u_center_av', u_center_av )
     2457       ENDIF
     2458
     2459       CALL rd_mpi_io_check_array( 'uu_av' , found = array_found )
     2460       IF ( array_found )  THEN
     2461          IF ( .NOT. ALLOCATED( uu_av ) )  ALLOCATE( uu_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2462          CALL rrd_mpi_io( 'uu_av', uu_av )
     2463       ENDIF
     2464
     2465       CALL rd_mpi_io_check_array( 'uv_10m_av' , found = array_found )
     2466       IF ( array_found )  THEN
     2467          IF ( .NOT. ALLOCATED( uv_10m_av ) )  ALLOCATE( uv_10m_av(nysg:nyng,nxlg:nxrg) )
     2468          CALL rrd_mpi_io( 'uv_10m_av', uv_10m_av )
     2469       ENDIF
     2470
     2471       CALL rd_mpi_io_check_array( 'u_m_l' , found = array_found )
     2472       IF ( array_found )  THEN
     2473          IF ( .NOT. ALLOCATED( u_m_l ) )  ALLOCATE( u_m_l(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2474          CALL rrd_mpi_io( 'u_m_l', u_m_l )
     2475       ENDIF
     2476
     2477       CALL rd_mpi_io_check_array( 'u_m_n' , found = array_found )
     2478       IF ( array_found )  THEN
     2479          IF ( .NOT. ALLOCATED( u_m_n ) )  ALLOCATE( u_m_n(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2480          CALL rrd_mpi_io( 'u_m_n', u_m_n )
     2481       ENDIF
     2482
     2483       CALL rd_mpi_io_check_array( 'u_m_r' , found = array_found )
     2484       IF ( array_found )  THEN
     2485          IF ( .NOT. ALLOCATED( u_m_r ) )  ALLOCATE( u_m_r(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2486          CALL rrd_mpi_io( 'u_m_r', u_m_r )
     2487       ENDIF
     2488
     2489       CALL rd_mpi_io_check_array( 'u_m_s' , found = array_found )
     2490       IF ( array_found )  THEN
     2491          IF ( .NOT. ALLOCATED( u_m_s ) )  ALLOCATE( u_m_s(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2492          CALL rrd_mpi_io( 'u_m_s', u_m_s )
     2493       ENDIF
     2494
     2495       CALL rd_mpi_io_check_array( 'us_av' , found = array_found )
     2496       IF ( array_found )  THEN
     2497          IF ( .NOT. ALLOCATED( us_av ) )  ALLOCATE( us_av(nysg:nyng,nxlg:nxrg) )
     2498          CALL rrd_mpi_io( 'us_av', us_av )
     2499       ENDIF
     2500
     2501       CALL rrd_mpi_io( 'v', v )
     2502
     2503       CALL rd_mpi_io_check_array( 'v_av' , found = array_found )
     2504       IF ( array_found )  THEN
     2505          IF ( .NOT. ALLOCATED( v_av ) )  ALLOCATE( v_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2506          CALL rrd_mpi_io( 'v_av', v_av )
     2507       ENDIF
     2508
     2509       CALL rd_mpi_io_check_array( 'v_center_av' , found = array_found )
     2510       IF ( array_found )  THEN
     2511          IF ( .NOT. ALLOCATED( v_center_av ) )  ALLOCATE( v_center_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2512          CALL rrd_mpi_io( 'v_center_av', v_center_av )
     2513       ENDIF
     2514
     2515       CALL rd_mpi_io_check_array( 'vv_av' , found = array_found )
     2516       IF ( array_found )  THEN
     2517          IF ( .NOT. ALLOCATED( vv_av ) )  ALLOCATE( vv_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2518          CALL rrd_mpi_io( 'vv_av', vv_av )
     2519       ENDIF
     2520
     2521       CALL rd_mpi_io_check_array( 'v_m_l' , found = array_found )
     2522       IF ( array_found )  THEN
     2523          IF ( .NOT. ALLOCATED( v_m_l ) )  ALLOCATE( v_m_l(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2524          CALL rrd_mpi_io( 'v_m_l', v_m_l )
     2525       ENDIF
     2526
     2527       CALL rd_mpi_io_check_array( 'v_m_n' , found = array_found )
     2528       IF ( array_found )  THEN
     2529          IF ( .NOT. ALLOCATED( v_m_n ) )  ALLOCATE( v_m_n(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2530          CALL rrd_mpi_io( 'v_m_n', v_m_n )
     2531       ENDIF
     2532
     2533       CALL rd_mpi_io_check_array( 'v_m_r' , found = array_found )
     2534       IF ( array_found )  THEN
     2535          IF ( .NOT. ALLOCATED( v_m_r ) )  ALLOCATE( v_m_r(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2536          CALL rrd_mpi_io( 'v_m_r', v_m_r )
     2537       ENDIF
     2538
     2539       CALL rd_mpi_io_check_array( 'v_m_s' , found = array_found )
     2540       IF ( array_found )  THEN
     2541          IF ( .NOT. ALLOCATED( v_m_s ) )  ALLOCATE( v_m_s(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2542          CALL rrd_mpi_io( 'v_m_s', v_m_s )
     2543       ENDIF
     2544
     2545       CALL rd_mpi_io_check_array( 'vpt' , found = array_found )
     2546       IF ( array_found )  THEN
     2547          CALL rrd_mpi_io( 'vpt',  vpt)
     2548       ENDIF
     2549
     2550       CALL rd_mpi_io_check_array( 'vpt_av' , found = array_found )
     2551       IF ( array_found )  THEN
     2552          IF ( .NOT. ALLOCATED( vpt_av ) )  ALLOCATE( vpt_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2553          CALL rrd_mpi_io( 'vpt_av', vpt_av )
     2554       ENDIF
     2555
     2556       CALL rrd_mpi_io( 'w', w)
     2557
     2558       CALL rd_mpi_io_check_array( 'w_av' , found = array_found )
     2559       IF ( array_found )  THEN
     2560          IF ( .NOT. ALLOCATED( w_av ) )  ALLOCATE( w_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2561          CALL rrd_mpi_io( 'w_av', w_av )
     2562       ENDIF
     2563
     2564       CALL rd_mpi_io_check_array( 'ww_av' , found = array_found )
     2565       IF ( array_found )  THEN
     2566          IF ( .NOT. ALLOCATED( ww_av ) )  ALLOCATE( w_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2567          CALL rrd_mpi_io( 'ww_av', ww_av )
     2568       ENDIF
     2569
     2570       CALL rd_mpi_io_check_array( 'w_m_l' , found = array_found )
     2571       IF ( array_found )  THEN
     2572          IF ( .NOT. ALLOCATED( w_m_l ) )  ALLOCATE( w_m_l(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2573          CALL rrd_mpi_io( 'w_m_l', w_m_l )
     2574       ENDIF
     2575
     2576       CALL rd_mpi_io_check_array( 'w_m_n' , found = array_found )
     2577       IF ( array_found )  THEN
     2578          IF ( .NOT. ALLOCATED( w_m_n ) )  ALLOCATE( w_m_n(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2579          CALL rrd_mpi_io( 'w_m_n', w_m_n )
     2580       ENDIF
     2581
     2582       CALL rd_mpi_io_check_array( 'w_m_r' , found = array_found )
     2583       IF ( array_found )  THEN
     2584          IF ( .NOT. ALLOCATED( w_m_r ) )  ALLOCATE( w_m_r(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2585          CALL rrd_mpi_io( 'w_m_r', w_m_r )
     2586       ENDIF
     2587
     2588       CALL rd_mpi_io_check_array( 'w_m_s' , found = array_found )
     2589       IF ( array_found )  THEN
     2590          IF ( .NOT. ALLOCATED( w_m_s ) )  ALLOCATE( w_m_s(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     2591          CALL rrd_mpi_io( 'w_m_s', w_m_s )
     2592       ENDIF
     2593
     2594       CALL rd_mpi_io_check_array( 'wspeed_av' , found = array_found )
     2595       IF ( array_found )  THEN
     2596          IF ( .NOT. ALLOCATED( wspeed_av ) )  ALLOCATE( wspeed_av(nzb:nzt+1,nys:nyn,nxl:nxr) )
     2597          CALL rrd_mpi_io( 'wspeed_av', wspeed_av )
     2598       ENDIF
     2599
     2600       CALL rd_mpi_io_check_array( 'z0_av' , found = array_found )
     2601       IF ( array_found )  THEN
     2602          IF ( .NOT. ALLOCATED( z0_av ) )  ALLOCATE( z0_av(nysg:nyng,nxlg:nxrg) )
     2603          CALL rrd_mpi_io( 'z0_av', z0_av )
     2604       ENDIF
     2605
     2606       CALL rd_mpi_io_check_array( 'z0h_av' , found = array_found )
     2607       IF ( array_found )  THEN
     2608          IF ( .NOT. ALLOCATED( z0h_av ) )  ALLOCATE( z0h_av(nysg:nyng,nxlg:nxrg) )
     2609          CALL rrd_mpi_io( 'z0h_av', z0h_av )
     2610       ENDIF
     2611
     2612       CALL rd_mpi_io_check_array( 'z0q_av' , found = array_found )
     2613       IF ( array_found )  THEN
     2614          IF ( .NOT. ALLOCATED( z0q_av ) )  ALLOCATE( z0q_av(nysg:nyng,nxlg:nxrg) )
     2615          CALL rrd_mpi_io( 'z0q_av', z0q_av )
     2616       ENDIF
     2617
     2618!
     2619!--    Read restart data of surfaces
     2620       CALL surface_rrd_local
     2621
     2622!
     2623!--    Read restart data of other modules
     2624       CALL module_interface_rrd_local
     2625
     2626!
     2627!--    Close restart file
     2628       CALL rd_mpi_io_close
     2629
     2630    ENDIF
    22522631
    22532632!
  • palm/trunk/SOURCE/surface_data_output_mod.f90

    r4502 r4517  
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4502 2020-04-17 16:14:16Z schwenkel
    2730! Implementation of ice microphysics
    2831!
     
    147150
    148151   USE restart_data_mpi_io_mod,                                                                    &
    149        ONLY:  rrd_mpi_io, wrd_mpi_io
     152       ONLY:  rd_mpi_io_check_array, rrd_mpi_io, wrd_mpi_io
    150153
    151154   USE surface_mod,                                                                                &
     
    267270
    268271   INTERFACE  surface_data_output_rrd_local
    269       MODULE PROCEDURE surface_data_output_rrd_local
     272      MODULE PROCEDURE surface_data_output_rrd_local_ftn
     273      MODULE PROCEDURE surface_data_output_rrd_local_mpi
    270274   END INTERFACE  surface_data_output_rrd_local
    271275
     
    48834887! Description:
    48844888! ------------
    4885 !> This routine reads the respective restart data.
     4889!> Read module-specific local restart data arrays (Fortran binary format).
    48864890!------------------------------------------------------------------------------!
    4887     SUBROUTINE surface_data_output_rrd_local( found )
     4891    SUBROUTINE surface_data_output_rrd_local_ftn( found )
    48884892
    48894893
     
    48954899       LOGICAL, INTENT(OUT)  ::  found
    48964900
    4897 !
    4898 !--    Here the reading of user-defined restart data follows:
    4899 !--    Sample for user-defined output
     4901
    49004902       found = .TRUE.
    49014903
     
    49124914
    49134915
    4914     END SUBROUTINE surface_data_output_rrd_local
     4916    END SUBROUTINE surface_data_output_rrd_local_ftn
     4917
     4918
     4919!------------------------------------------------------------------------------!
     4920! Description:
     4921! ------------
     4922!> Read module-specific local restart data arrays (MPI-IO).
     4923!------------------------------------------------------------------------------!
     4924    SUBROUTINE surface_data_output_rrd_local_mpi
     4925
     4926       IMPLICIT NONE
     4927
     4928       LOGICAL ::  array_found  !<
     4929
     4930
     4931       CALL rd_mpi_io_check_array( 'surfaces%var_av' , found = array_found )
     4932
     4933!> does not work this way: surface%var_av has non-standard dimensions
     4934!       IF ( array_found )  THEN
     4935!          IF ( .NOT. ALLOCATED( surfaces%var_av ) )  ALLOCATE( ....... )
     4936!          CALL rrd_mpi_io( 'surfaces%var_av', surfaces%var_av )
     4937!       ENDIF
     4938
     4939    END SUBROUTINE surface_data_output_rrd_local_mpi
     4940
    49154941
    49164942!------------------------------------------------------------------------------!
     
    49364962    END SUBROUTINE surface_data_output_wrd_global
    49374963
     4964
    49384965!------------------------------------------------------------------------------!
    49394966! Description:
  • palm/trunk/SOURCE/surface_mod.f90

    r4502 r4517  
    2626! -----------------
    2727! $Id$
     28! added restart with MPI-IO for reading local arrays
     29!
     30! 4502 2020-04-17 16:14:16Z schwenkel
    2831! Implementation of ice microphysics
    2932!
     
    145148
    146149    USE restart_data_mpi_io_mod,                                                                   &
    147         ONLY:  rd_mpi_io_surface_filetypes, total_number_of_surface_values, wrd_mpi_io,            &
     150        ONLY:  rd_mpi_io_surface_filetypes, rrd_mpi_io, rrd_mpi_io_global_array,                   &
     151               rrd_mpi_io_surface, total_number_of_surface_values, wrd_mpi_io,                     &
    148152               wrd_mpi_io_global_array, wrd_mpi_io_surface
    149153
     
    499503
    500504    INTERFACE surface_rrd_local
    501        MODULE PROCEDURE surface_rrd_local
     505       MODULE PROCEDURE surface_rrd_local_ftn
     506       MODULE PROCEDURE surface_rrd_local_mpi
    502507    END INTERFACE surface_rrd_local
    503508
     
    42364241! Description:
    42374242! ------------
    4238 !> Reads surface-related restart data. Please note, restart data for a certain
     4243!> Reads surface-related restart data in Fortran binary format. Please note, restart data for a certain
    42394244!> surface orientation (e.g. horizontal upward-facing) is stored in one
    42404245!> array, even if surface elements may belong to different surface types
     
    42444249!> of cyclic_fill mode.
    42454250!------------------------------------------------------------------------------!
    4246     SUBROUTINE surface_rrd_local( kk, nxlf, nxlc, nxl_on_file, nxrf,           &
    4247                                   nxr_on_file, nynf, nyn_on_file, nysf,        &
    4248                                   nysc, nys_on_file, found )
     4251    SUBROUTINE surface_rrd_local_ftn( kk, nxlf, nxlc, nxl_on_file, nxrf,           &
     4252                                      nxr_on_file, nynf, nyn_on_file, nysf,        &
     4253                                      nysc, nys_on_file, found )
    42494254
    42504255
     
    51855190       ENDIF
    51865191
    5187 
    5188     CONTAINS
     5192 CONTAINS
    51895193!------------------------------------------------------------------------------!
    51905194! Description:
     
    54035407
    54045408
    5405     END SUBROUTINE surface_rrd_local
     5409    END SUBROUTINE surface_rrd_local_ftn
     5410
     5411
     5412!------------------------------------------------------------------------------!
     5413! Description:
     5414! ------------
     5415!> Reads surface-related restart data in MPI-IO format.
     5416!> TO_DO: this routine needs to be adjusted for cyclic_fill mode
     5417!------------------------------------------------------------------------------!
     5418 SUBROUTINE surface_rrd_local_mpi
     5419
     5420
     5421    IMPLICIT NONE
     5422
     5423    CHARACTER(LEN=1) ::  dum  !< dummy string to create input-variable name
     5424
     5425    INTEGER(iwp) ::  l  !< loop index for surface types
     5426
     5427    INTEGER(iwp), DIMENSION(nys:nyn,nxl:nxr) ::  global_start_index  !< index for surface data (MPI-IO)
     5428
     5429    LOGICAL ::  ldum  !< dummy variable
     5430
     5431    TYPE(surf_type), DIMENSION(0:2) ::  surf_h     !< gathered horizontal surfaces, contains all surface types
     5432    TYPE(surf_type), DIMENSION(0:3) ::  surf_v     !< gathered vertical surfaces, contains all surface types
     5433
     5434!
     5435!-- Get total number of surface points on the file
     5436    CALL rrd_mpi_io_global_array( 'ns_h_on_file', ns_h_on_file )
     5437    CALL rrd_mpi_io_global_array( 'ns_v_on_file', ns_v_on_file )
     5438
     5439
     5440    DO  l = 0, 2
     5441
     5442       IF ( ns_h_on_file(l) == 0 )  CYCLE  !< no data of this surface type on file
     5443
     5444       IF ( ALLOCATED( surf_h(l)%start_index ) )  CALL deallocate_surface_attributes_h( surf_h(l) )
     5445       surf_h(l)%ns = ns_h_on_file(l)
     5446       CALL allocate_surface_attributes_h( surf_h(l), nys, nyn, nxl, nxr )
     5447
     5448       WRITE( dum, '(I1)')  l
     5449
     5450       CALL rrd_mpi_io( 'surf_h(' // dum // ')%start_index',  surf_h(l)%start_index )
     5451       CALL rrd_mpi_io( 'surf_h(' // dum // ')%end_index',  surf_h(l)%end_index )
     5452       CALL rrd_mpi_io( 'global_start_index_h_' // dum , global_start_index )
     5453
     5454       CALL rd_mpi_io_surface_filetypes( surf_h(l)%start_index, surf_h(l)%end_index, ldum, global_start_index )
     5455
     5456       IF ( ALLOCATED ( surf_h(l)%us ) )  THEN
     5457          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%us', surf_h(l)%us )
     5458       ENDIF
     5459
     5460       IF ( ALLOCATED ( surf_h(l)%ts ) )  THEN
     5461          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ts', surf_h(l)%ts )
     5462       ENDIF
     5463
     5464       IF ( ALLOCATED ( surf_h(l)%qs ) )  THEN
     5465          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qs', surf_h(l)%qs )
     5466       ENDIF
     5467
     5468       IF ( ALLOCATED ( surf_h(l)%ss ) )  THEN
     5469          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ss', surf_h(l)%ss )
     5470       ENDIF
     5471
     5472       IF ( ALLOCATED ( surf_h(l)%qcs ) )  THEN
     5473          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qcs', surf_h(l)%qcs )
     5474       ENDIF
     5475
     5476       IF ( ALLOCATED ( surf_h(l)%ncs ) )  THEN
     5477          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ncs', surf_h(l)%ncs )
     5478       ENDIF
     5479
     5480       IF ( ALLOCATED ( surf_h(l)%qis ) )  THEN
     5481          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qis', surf_h(l)%qis )
     5482       ENDIF
     5483
     5484       IF ( ALLOCATED ( surf_h(l)%nis ) )  THEN
     5485          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%nis', surf_h(l)%nis )
     5486       ENDIF
     5487
     5488       IF ( ALLOCATED ( surf_h(l)%qrs ) )  THEN
     5489          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qrs', surf_h(l)%qrs )
     5490       ENDIF
     5491
     5492       IF ( ALLOCATED ( surf_h(l)%nrs ) )  THEN
     5493          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%nrs', surf_h(l)%nrs )
     5494       ENDIF
     5495
     5496       IF ( ALLOCATED ( surf_h(l)%ol ) )  THEN
     5497          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ol', surf_h(l)%ol )
     5498       ENDIF
     5499
     5500       IF ( ALLOCATED ( surf_h(l)%rib ) )  THEN
     5501          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%rib',  surf_h(l)%rib )
     5502       ENDIF
     5503
     5504       IF ( ALLOCATED ( surf_h(l)%pt_surface ) )  THEN
     5505          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%pt_surface', surf_h(l)%pt_surface )
     5506       ENDIF
     5507
     5508       IF ( ALLOCATED ( surf_h(l)%q_surface ) )  THEN
     5509          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%q_surface', surf_h(l)%q_surface )
     5510       ENDIF
     5511
     5512       IF ( ALLOCATED ( surf_h(l)%vpt_surface ) )  THEN
     5513          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%vpt_surface', surf_h(l)%vpt_surface )
     5514       ENDIF
     5515
     5516       IF ( ALLOCATED ( surf_h(l)%usws ) )  THEN
     5517          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%usws', surf_h(l)%usws )
     5518       ENDIF
     5519
     5520       IF ( ALLOCATED ( surf_h(l)%vsws ) )  THEN
     5521          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%vsws', surf_h(l)%vsws )
     5522       ENDIF
     5523
     5524       IF ( ALLOCATED ( surf_h(l)%shf ) )  THEN
     5525          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%shf', surf_h(l)%shf )
     5526       ENDIF
     5527
     5528       IF ( ALLOCATED ( surf_h(l)%qsws ) )  THEN
     5529          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qsws', surf_h(l)%qsws )
     5530       ENDIF
     5531
     5532       IF ( ALLOCATED ( surf_h(l)%ssws ) )  THEN
     5533          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ssws', surf_h(l)%ssws )
     5534       ENDIF
     5535
     5536       IF ( ALLOCATED ( surf_h(l)%css ) )  THEN
     5537          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%css', surf_h(l)%css )
     5538       ENDIF
     5539
     5540       IF ( ALLOCATED ( surf_h(l)%cssws ) )  THEN
     5541          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%cssws', surf_h(l)%cssws )
     5542       ENDIF
     5543
     5544       IF ( ALLOCATED ( surf_h(l)%qcsws ) )  THEN
     5545          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qcsws', surf_h(l)%qcsws )
     5546       ENDIF
     5547
     5548       IF ( ALLOCATED ( surf_h(l)%ncsws ) )  THEN
     5549          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%ncsws', surf_h(l)%ncsws )
     5550       ENDIF
     5551
     5552       IF ( ALLOCATED ( surf_h(l)%qisws ) )  THEN
     5553          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qisws', surf_h(l)%qisws )
     5554       ENDIF
     5555
     5556       IF ( ALLOCATED ( surf_h(l)%nisws ) )  THEN
     5557          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%nisws', surf_h(l)%nisws )
     5558       ENDIF
     5559
     5560       IF ( ALLOCATED ( surf_h(l)%qrsws ) )  THEN
     5561          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%qrsws', surf_h(l)%qrsws )
     5562       ENDIF
     5563
     5564       IF ( ALLOCATED ( surf_h(l)%nrsws ) )  THEN
     5565          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%nrsws', surf_h(l)%nrsws )
     5566       ENDIF
     5567
     5568       IF ( ALLOCATED ( surf_h(l)%sasws ) )  THEN
     5569          CALL rrd_mpi_io_surface( 'surf_h(' // dum // ')%sasws', surf_h(l)%sasws )
     5570       ENDIF
     5571
     5572    ENDDO
     5573
     5574!
     5575!-- Read vertical surfaces
     5576    DO  l = 0, 3
     5577
     5578       IF ( ns_v_on_file(l) == 0 )  CYCLE  !< no data of this surface type on file
     5579
     5580       IF ( ALLOCATED( surf_v(l)%start_index ) )  CALL deallocate_surface_attributes_v( surf_v(l) )
     5581       surf_v(l)%ns = ns_v_on_file(l)
     5582       CALL allocate_surface_attributes_v( surf_v(l), nys, nyn, nxl, nxr )
     5583
     5584       WRITE( dum, '(I1)' )  l
     5585
     5586       CALL rrd_mpi_io( 'surf_v(' // dum // ')%start_index', surf_v(l)%start_index )
     5587       CALL rrd_mpi_io( 'surf_v(' // dum // ')%end_index', surf_v(l)%end_index )
     5588       CALL rrd_mpi_io( 'global_start_index_v_' // dum , global_start_index )
     5589
     5590       CALL rd_mpi_io_surface_filetypes( surf_v(l)%start_index, surf_v(l)%end_index, ldum,         &
     5591                                         global_start_index )
     5592
     5593       IF ( ALLOCATED ( surf_v(l)%us ) )  THEN
     5594          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%us',  surf_v(l)%us )
     5595       ENDIF
     5596
     5597       IF ( ALLOCATED ( surf_v(l)%ts ) )  THEN
     5598          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ts', surf_v(l)%ts )
     5599       ENDIF
     5600
     5601       IF ( ALLOCATED ( surf_v(l)%qs ) )  THEN
     5602          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qs',  surf_v(l)%qs )
     5603       ENDIF
     5604
     5605       IF ( ALLOCATED ( surf_v(l)%ss ) )  THEN
     5606          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ss',  surf_v(l)%ss )
     5607       ENDIF
     5608
     5609       IF ( ALLOCATED ( surf_v(l)%qcs ) )  THEN
     5610          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qcs', surf_v(l)%qcs )
     5611       ENDIF
     5612
     5613       IF ( ALLOCATED ( surf_v(l)%ncs ) )  THEN
     5614          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ncs', surf_v(l)%ncs )
     5615       ENDIF
     5616
     5617       IF ( ALLOCATED ( surf_v(l)%qis ) )  THEN
     5618          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qis', surf_v(l)%qis )
     5619       ENDIF
     5620
     5621       IF ( ALLOCATED ( surf_v(l)%nis ) )  THEN
     5622          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%nis', surf_v(l)%nis )
     5623       ENDIF
     5624
     5625       IF ( ALLOCATED ( surf_v(l)%qrs ) )  THEN
     5626          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qrs', surf_v(l)%qrs )
     5627       ENDIF
     5628
     5629       IF ( ALLOCATED ( surf_v(l)%nrs ) )  THEN
     5630          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%nrs', surf_v(l)%nrs )
     5631       ENDIF
     5632
     5633       IF ( ALLOCATED ( surf_v(l)%ol ) )  THEN
     5634          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ol', surf_v(l)%ol )
     5635       ENDIF
     5636
     5637       IF ( ALLOCATED ( surf_v(l)%rib ) )  THEN
     5638          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%rib', surf_v(l)%rib )
     5639       ENDIF
     5640
     5641       IF ( ALLOCATED ( surf_v(l)%pt_surface ) )  THEN
     5642          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%pt_surface', surf_v(l)%pt_surface )
     5643       ENDIF
     5644
     5645       IF ( ALLOCATED ( surf_v(l)%q_surface ) )  THEN
     5646          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%q_surface', surf_v(l)%q_surface )
     5647       ENDIF
     5648
     5649       IF ( ALLOCATED ( surf_v(l)%vpt_surface ) )  THEN
     5650          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%vpt_surface', surf_v(l)%vpt_surface )
     5651       ENDIF
     5652
     5653       IF ( ALLOCATED ( surf_v(l)%shf ) )  THEN
     5654          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%shf', surf_v(l)%shf )
     5655       ENDIF
     5656
     5657       IF ( ALLOCATED ( surf_v(l)%qsws ) )  THEN
     5658          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qsws', surf_v(l)%qsws )
     5659       ENDIF
     5660
     5661       IF ( ALLOCATED ( surf_v(l)%ssws ) )  THEN
     5662          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ssws', surf_v(l)%ssws )
     5663       ENDIF
     5664
     5665       IF ( ALLOCATED ( surf_v(l)%css ) )  THEN
     5666          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%css', surf_v(l)%css )
     5667       ENDIF
     5668
     5669       IF ( ALLOCATED ( surf_v(l)%cssws ) )  THEN
     5670          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%cssws', surf_v(l)%cssws )
     5671       ENDIF
     5672
     5673       IF ( ALLOCATED ( surf_v(l)%qcsws ) )  THEN
     5674          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qcsws', surf_v(l)%qcsws )
     5675       ENDIF
     5676
     5677       IF ( ALLOCATED ( surf_v(l)%ncsws ) )  THEN
     5678          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%ncsws', surf_v(l)%ncsws )
     5679       ENDIF
     5680
     5681       IF ( ALLOCATED ( surf_v(l)%qisws ) )  THEN
     5682          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qisws', surf_v(l)%qisws )
     5683       ENDIF
     5684
     5685       IF ( ALLOCATED ( surf_v(l)%nisws ) )  THEN
     5686          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%nisws', surf_v(l)%nisws )
     5687       ENDIF
     5688
     5689       IF ( ALLOCATED ( surf_v(l)%qrsws ) )  THEN
     5690          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%qrsws', surf_v(l)%qrsws )
     5691       ENDIF
     5692
     5693       IF ( ALLOCATED ( surf_v(l)%nrsws ) )  THEN
     5694          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%nrsws', surf_v(l)%nrsws )
     5695       ENDIF
     5696
     5697       IF ( ALLOCATED ( surf_v(l)%sasws ) )  THEN
     5698          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%sasws', surf_v(l)%sasws )
     5699       ENDIF
     5700
     5701       IF ( ALLOCATED ( surf_v(l)%mom_flux_uv ) )  THEN
     5702          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%mom_uv', surf_v(l)%mom_flux_uv)
     5703       ENDIF
     5704
     5705       IF ( ALLOCATED ( surf_v(l)%mom_flux_w ) )  THEN
     5706          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%mom_w',  surf_v(l)%mom_flux_w)
     5707       ENDIF
     5708
     5709       IF ( ALLOCATED ( surf_v(l)%mom_flux_tke ) )  THEN
     5710          CALL rrd_mpi_io_surface( 'surf_v(' // dum // ')%mom_tke', surf_v(l)%mom_flux_tke)
     5711       ENDIF
     5712
     5713    ENDDO
     5714
     5715!
     5716!-- Redistribute surface elements on its respective type.
     5717
     5718    DO  l = 0 , 2
     5719       CALL restore_surface_elements( surf_def_h(l), surf_h(l) )
     5720       CALL restore_surface_elements( surf_lsm_h, surf_h(l) )
     5721       CALL restore_surface_elements( surf_usm_h, surf_h(l) )
     5722    ENDDO
     5723
     5724    DO  l = 0 , 3
     5725       CALL restore_surface_elements( surf_def_v(l), surf_v(l) )
     5726       CALL restore_surface_elements( surf_lsm_v(l), surf_v(l) )
     5727       CALL restore_surface_elements( surf_usm_v(l), surf_v(l) )
     5728    ENDDO
     5729
     5730 CONTAINS
     5731
     5732          SUBROUTINE restore_surface_elements( surf_target, surf_file )
     5733
     5734             IMPLICIT NONE
     5735
     5736             INTEGER(iwp)      ::  lsp         !< running index chemical species
     5737
     5738             TYPE( surf_type ) ::  surf_target !< target surface type
     5739             TYPE( surf_type ) ::  surf_file   !< surface type on file
     5740
     5741
     5742             IF ( ALLOCATED( surf_target%us )  .AND. ALLOCATED( surf_file%us   ) )      THEN
     5743                surf_target%us = surf_file%us
     5744             ENDIF
     5745
     5746             IF ( ALLOCATED( surf_target%ol )  .AND.                        &
     5747                ALLOCATED( surf_file%ol   ) )                             &
     5748                surf_target%ol = surf_file%ol
     5749
     5750             IF ( ALLOCATED( surf_target%pt_surface )  .AND.                &
     5751                ALLOCATED( surf_file%pt_surface   ) )                     &
     5752                surf_target%pt_surface = surf_file%pt_surface
     5753
     5754             IF ( ALLOCATED( surf_target%q_surface )  .AND.                 &
     5755                ALLOCATED( surf_file%q_surface   ) )                      &
     5756                surf_target%q_surface = surf_file%q_surface
     5757
     5758             IF ( ALLOCATED( surf_target%vpt_surface )  .AND.               &
     5759                ALLOCATED( surf_file%vpt_surface   ) )                    &
     5760                surf_target%vpt_surface = surf_file%vpt_surface
     5761
     5762             IF ( ALLOCATED( surf_target%usws )  .AND.                      &
     5763                ALLOCATED( surf_file%usws   ) )                           &
     5764                surf_target%usws = surf_file%usws
     5765
     5766             IF ( ALLOCATED( surf_target%vsws )  .AND.                      &
     5767                ALLOCATED( surf_file%vsws   ) )                           &
     5768                surf_target%vsws = surf_file%vsws
     5769
     5770             IF ( ALLOCATED( surf_target%ts )  .AND.                        &
     5771                ALLOCATED( surf_file%ts   ) )                             &
     5772                surf_target%ts = surf_file%ts
     5773
     5774             IF ( ALLOCATED( surf_target%shf )  .AND.                       &
     5775                ALLOCATED( surf_file%shf   ) )                            &
     5776                surf_target%shf = surf_file%shf
     5777
     5778             IF ( ALLOCATED( surf_target%qs )  .AND.                        &
     5779                ALLOCATED( surf_file%qs   ) )                             &
     5780                surf_target%qs = surf_file%qs
     5781
     5782             IF ( ALLOCATED( surf_target%qsws )  .AND.                      &
     5783                ALLOCATED( surf_file%qsws   ) )                           &
     5784                surf_target%qsws = surf_file%qsws
     5785
     5786             IF ( ALLOCATED( surf_target%ss )  .AND.                        &
     5787                ALLOCATED( surf_file%ss   ) )                             &
     5788                surf_target%ss = surf_file%ss
     5789
     5790             IF ( ALLOCATED( surf_target%ssws )  .AND.                      &
     5791                ALLOCATED( surf_file%ssws   ) )                           &
     5792                surf_target%ssws = surf_file%ssws
     5793
     5794             IF ( ALLOCATED( surf_target%css )  .AND.                     &
     5795                ALLOCATED( surf_file%css   ) )  THEN
     5796                DO  lsp = 1, nvar
     5797                   surf_target%css(lsp,:) = surf_file%css(lsp,:)
     5798                ENDDO
     5799             ENDIF
     5800
     5801             IF ( ALLOCATED( surf_target%cssws )  .AND.                     &
     5802                ALLOCATED( surf_file%cssws   ) )  THEN
     5803                DO  lsp = 1, nvar
     5804                   surf_target%cssws(lsp,:) = surf_file%cssws(lsp,:)
     5805                ENDDO
     5806             ENDIF
     5807             IF ( ALLOCATED( surf_target%qcs )  .AND.                       &
     5808                ALLOCATED( surf_file%qcs   ) )                            &
     5809                surf_target%qcs = surf_file%qcs
     5810             IF ( ALLOCATED( surf_target%qcsws )  .AND.                     &
     5811                ALLOCATED( surf_file%qcsws   ) )                          &
     5812                surf_target%qcsws = surf_file%qcsws
     5813             IF ( ALLOCATED( surf_target%ncs )  .AND.                       &
     5814                ALLOCATED( surf_file%ncs   ) )                            &
     5815                surf_target%ncs = surf_file%ncs
     5816             IF ( ALLOCATED( surf_target%ncsws )  .AND.                     &
     5817                ALLOCATED( surf_file%ncsws   ) )                          &
     5818                surf_target%ncsws = surf_file%ncsws
     5819             IF ( ALLOCATED( surf_target%qrs )  .AND.                       &
     5820                ALLOCATED( surf_file%qrs   ) )                            &
     5821                surf_target%qrs = surf_file%qrs
     5822             IF ( ALLOCATED( surf_target%qrsws )  .AND.                     &
     5823                ALLOCATED( surf_file%qrsws   ) )                          &
     5824                surf_target%qrsws = surf_file%qrsws
     5825             IF ( ALLOCATED( surf_target%nrs )  .AND.                       &
     5826                ALLOCATED( surf_file%nrs   ) )                            &
     5827                surf_target%nrs = surf_file%nrs
     5828
     5829             IF ( ALLOCATED( surf_target%nrsws )  .AND.                     &
     5830                ALLOCATED( surf_file%nrsws   ) )                          &
     5831                surf_target%nrsws = surf_file%nrsws
     5832             IF ( ALLOCATED( surf_target%sasws )  .AND.                     &
     5833                ALLOCATED( surf_file%sasws   ) )                          &
     5834                surf_target%sasws = surf_file%sasws
     5835             IF ( ALLOCATED( surf_target%mom_flux_uv )  .AND.               &
     5836                ALLOCATED( surf_file%mom_flux_uv   ) )                    &
     5837                surf_target%mom_flux_uv =                         &
     5838                surf_file%mom_flux_uv
     5839             IF ( ALLOCATED( surf_target%mom_flux_w )  .AND.                &
     5840                ALLOCATED( surf_file%mom_flux_w   ) )                     &
     5841                surf_target%mom_flux_w =                          &
     5842                surf_file%mom_flux_w
     5843             IF ( ALLOCATED( surf_target%mom_flux_tke )  .AND.              &
     5844                ALLOCATED( surf_file%mom_flux_tke   ) )                   &
     5845                surf_target%mom_flux_tke(0:1,:) =                    &
     5846                surf_file%mom_flux_tke(0:1,:)
     5847
     5848
     5849          END SUBROUTINE restore_surface_elements
     5850
     5851 END SUBROUTINE surface_rrd_local_mpi
     5852
     5853
     5854
    54065855
    54075856
  • palm/trunk/SOURCE/urban_surface_mod.f90

    r4510 r4517  
    2727! -----------------
    2828! $Id$
     29! added restart with MPI-IO for reading local arrays
     30!
     31! 4510 2020-04-29 14:19:18Z raasch
    2932! Further re-formatting to follow the PALM coding standard
    3033!
     
    368371    USE restart_data_mpi_io_mod,                                                                   &
    369372        ONLY:  rd_mpi_io_surface_filetypes,                                                        &
     373               rrd_mpi_io,                                                                         &
     374               rrd_mpi_io_surface,                                                                 &
    370375               wrd_mpi_io,                                                                         &
    371376               wrd_mpi_io_surface
     
    617622
    618623
    619 
    620 
    621624!
    622625!-- Building facade/wall/green/window properties (partly according to PIDS).
     
    840843
    841844    INTERFACE usm_rrd_local
    842        MODULE PROCEDURE usm_rrd_local
     845       MODULE PROCEDURE usm_rrd_local_ftn
     846       MODULE PROCEDURE usm_rrd_local_mpi
    843847    END INTERFACE usm_rrd_local
    844848
     
    61106114! Description:
    61116115! ------------
    6112 !> Soubroutine reads t_surf and t_wall data from restart files
     6116!> Read module-specific local restart data arrays (Fortran binary format).
     6117!> Soubroutine reads t_surf and t_wall.
    61136118!--------------------------------------------------------------------------------------------------!
    6114  SUBROUTINE usm_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxr_on_file, nynf, nyn_on_file,       &
    6115                            nysf, nysc, nys_on_file, found )
     6119 SUBROUTINE usm_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxr_on_file, nynf, nyn_on_file,   &
     6120                               nysf, nysc, nys_on_file, found )
    61166121
    61176122
     
    66546659    END SELECT
    66556660
    6656  END SUBROUTINE usm_rrd_local
     6661 END SUBROUTINE usm_rrd_local_ftn
     6662
     6663
     6664!--------------------------------------------------------------------------------------------------!
     6665! Description:
     6666! ------------
     6667!> Read module-specific local restart data arrays (MPI-IO).
     6668!> Soubroutine reads t_surf and t_wall.
     6669!>
     6670!> This read routine is a counterpart of usm_wrd_local.
     6671!> In usm_wrd_local, all array are unconditionally written, therefore all arrays are read here.
     6672!> This is a preliminary version of reading usm data. The final version has to be discussed with
     6673!> the developers.
     6674!>
     6675!> If it is possible to call usm_allocate_surface before reading the restart file, this reading
     6676!> routine would become much simpler, because no checking for allocation will be necessary any more.
     6677!--------------------------------------------------------------------------------------------------!
     6678 SUBROUTINE usm_rrd_local_mpi
     6679
     6680
     6681    CHARACTER(LEN=1) ::  dum  !< dummy string to create input-variable name
     6682
     6683    INTEGER(iwp) ::  l  !< loop index for surface types
     6684
     6685    INTEGER(iwp), DIMENSION(nys:nyn,nxl:nxr) ::  global_start
     6686
     6687    LOGICAL ::  ldum  !< dummy variable
     6688
     6689
     6690    CALL rrd_mpi_io( 'usm_start_index_h',  surf_usm_h%start_index )
     6691    CALL rrd_mpi_io( 'usm_end_index_h', surf_usm_h%end_index )
     6692    CALL rrd_mpi_io( 'usm_global_start_h', global_start )
     6693
     6694    CALL rd_mpi_io_surface_filetypes( surf_usm_h%start_index, surf_usm_h%end_index, ldum,          &
     6695                                      global_start )
     6696
     6697    IF ( .NOT.  ALLOCATED( t_surf_wall_h_1 ) )  ALLOCATE( t_surf_wall_h_1(1:surf_usm_h%ns) )
     6698    CALL rrd_mpi_io_surface( 't_surf_wall_h', t_surf_wall_h_1 )
     6699
     6700    IF ( .NOT.  ALLOCATED( t_surf_window_h_1 ) )  ALLOCATE( t_surf_window_h_1(1:surf_usm_h%ns) )
     6701    CALL rrd_mpi_io_surface( 't_surf_window_h', t_surf_window_h_1 )
     6702
     6703    IF ( .NOT.  ALLOCATED( t_surf_green_h_1 ) )  ALLOCATE( t_surf_green_h_1(1:surf_usm_h%ns) )
     6704    CALL rrd_mpi_io_surface( 't_surf_green_h', t_surf_green_h_1 )
     6705
     6706    DO  l = 0, 3
     6707
     6708       WRITE( dum, '(I1)' )  l
     6709
     6710       CALL rrd_mpi_io( 'usm_start_index_v_' //dum, surf_usm_v(l)%start_index )
     6711       CALL rrd_mpi_io( 'usm_end_index_v_' // dum, surf_usm_v(l)%end_index )
     6712       CALL rrd_mpi_io( 'usm_global_start_v_' // dum, global_start )
     6713
     6714       CALL rd_mpi_io_surface_filetypes( surf_usm_v(l)%start_index, surf_usm_v(l)%end_index, ldum, &
     6715                                         global_start )
     6716
     6717       IF ( .NOT.  ALLOCATED( t_surf_wall_v_1(l)%t ) )                                             &
     6718          ALLOCATE( t_surf_wall_v_1(l)%t(1:surf_usm_v(l)%ns) )
     6719       CALL rrd_mpi_io_surface( 't_surf_wall_v(' // dum // ')', t_surf_wall_v_1(l)%t )
     6720
     6721       IF ( .NOT.  ALLOCATED( t_surf_window_v_1(l)%t ) )                                           &
     6722          ALLOCATE( t_surf_window_v_1(l)%t(1:surf_usm_v(l)%ns) )
     6723       CALL rrd_mpi_io_surface( 't_surf_window_v(' // dum // ')', t_surf_window_v_1(l)%t )
     6724
     6725       IF ( .NOT.  ALLOCATED( t_surf_green_v_1(l)%t ) )                                            &
     6726          ALLOCATE( t_surf_green_v_1(l)%t(1:surf_usm_v(l)%ns) )
     6727       CALL rrd_mpi_io_surface( 't_surf_green_v(' // dum // ')', t_surf_green_v_1(l)%t)
     6728
     6729    ENDDO
     6730
     6731    CALL rrd_mpi_io( 'usm_start_index_h_2',  surf_usm_h%start_index )
     6732    CALL rrd_mpi_io( 'usm_end_index_h_2', surf_usm_h%end_index )
     6733    CALL rrd_mpi_io( 'usm_global_start_h_2', global_start )
     6734
     6735    CALL rd_mpi_io_surface_filetypes( surf_usm_h%start_index, surf_usm_h%end_index, ldum,          &
     6736                                      global_start )
     6737
     6738    IF ( .NOT.  ALLOCATED( t_wall_h_1 ) )                                                          &
     6739       ALLOCATE( t_wall_h_1(nzb_wall:nzt_wall+1,1:surf_usm_h%ns) )
     6740    CALL rrd_mpi_io_surface( 't_wall_h', t_wall_h_1 )
     6741
     6742    IF ( .NOT.  ALLOCATED( t_window_h_1 ) )                                                        &
     6743       ALLOCATE( t_window_h_1(nzb_wall:nzt_wall+1,1:surf_usm_h%ns) )
     6744    CALL rrd_mpi_io_surface( 't_window_h', t_window_h_1 )
     6745
     6746    IF ( .NOT.  ALLOCATED( t_green_h_1 ) )                                                         &
     6747       ALLOCATE( t_green_h_1(nzb_wall:nzt_wall+1,1:surf_usm_h%ns) )
     6748    CALL rrd_mpi_io_surface( 't_green_h', t_green_h_1 )
     6749
     6750    DO  l = 0, 3
     6751
     6752       WRITE( dum, '(I1)' )  l
     6753
     6754       CALL rrd_mpi_io( 'usm_start_index_v_2_' //dum, surf_usm_v(l)%start_index )
     6755       CALL rrd_mpi_io( 'usm_end_index_v_2_' // dum, surf_usm_v(l)%end_index )
     6756       CALL rrd_mpi_io( 'usm_global_start_v_2_' // dum, global_start )
     6757
     6758       CALL rd_mpi_io_surface_filetypes( surf_usm_v(l)%start_index, surf_usm_v(l)%end_index, ldum, &
     6759                                         global_start )
     6760
     6761       IF ( .NOT. ALLOCATED( t_wall_v_1(l)%t ) )                                                   &
     6762          ALLOCATE ( t_wall_v_1(l)%t(nzb_wall:nzt_wall+1,1:surf_usm_v(l)%ns) )
     6763       CALL rrd_mpi_io_surface( 't_wall_v(' // dum // ')', t_wall_v_1(l)%t )
     6764
     6765       IF ( .NOT. ALLOCATED( t_window_v_1(l)%t ) )                                                 &
     6766          ALLOCATE ( t_window_v_1(l)%t(nzb_wall:nzt_wall+1,1:surf_usm_v(l)%ns) )
     6767       CALL rrd_mpi_io_surface( 't_window_v(' // dum // ')', t_window_v_1(l)%t )
     6768
     6769       IF ( .NOT. ALLOCATED( t_green_v_1(l)%t ) )                                                  &
     6770          ALLOCATE ( t_green_v_1(l)%t(nzb_wall:nzt_wall+1,1:surf_usm_v(l)%ns) )
     6771       CALL rrd_mpi_io_surface( 't_green_v(' // dum // ')', t_green_v_1(l)%t )
     6772
     6773    ENDDO
     6774
     6775 END SUBROUTINE usm_rrd_local_mpi
     6776
    66576777
    66586778
  • palm/trunk/SOURCE/user_module.f90

    r4504 r4517  
    2121! -----------------
    2222!
    23 !
     23! 
    2424! Former revisions:
    2525! -----------------
    2626! $Id$
     27! added restart with MPI-IO for reading local arrays
     28!
     29! 4504 2020-04-20 12:11:24Z raasch
    2730! hint for setting rmask arrays added
    2831!
     
    207210
    208211    INTERFACE user_rrd_local
    209        MODULE PROCEDURE user_rrd_local
     212       MODULE PROCEDURE user_rrd_local_ftn
     213       MODULE PROCEDURE user_rrd_local_mpi
    210214    END INTERFACE user_rrd_local
    211215
     
    11301134 SUBROUTINE user_rrd_global_mpi
    11311135
     1136!    USE restart_data_mpi_io_mod,                                                                   &
     1137!        ONLY:  rrd_mpi_io
     1138
    11321139!    CALL rrd_mpi_io( 'global_parameter', global_parameter )
    11331140    CONTINUE
     
    11391146! Description:
    11401147! ------------
    1141 !> Reading processor specific restart data from file(s) that has been defined by the user. Subdomain
     1148!> Read module-specific local restart data arrays (Fortran binary format).
     1149!> Subdomain
    11421150!> index limits on file are given by nxl_on_file, etc. Indices nxlc, etc. indicate the range of
    11431151!> gridpoints to be mapped from the subdomain on file (f) to the subdomain of the current PE (c).
    11441152!> They have been calculated in routine rrd_local.
    11451153!--------------------------------------------------------------------------------------------------!
    1146  SUBROUTINE user_rrd_local( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc, nxr_on_file, nynf, nync,       &
    1147                             nyn_on_file, nysf, nysc, nys_on_file, tmp_3d, found )
     1154 SUBROUTINE user_rrd_local_ftn( k, nxlf, nxlc, nxl_on_file, nxrf, nxrc, nxr_on_file, nynf, nync,   &
     1155                                nyn_on_file, nysf, nysc, nys_on_file, tmp_3d, found )
    11481156
    11491157
     
    11941202    END SELECT
    11951203
    1196  END SUBROUTINE user_rrd_local
     1204 END SUBROUTINE user_rrd_local_ftn
     1205
     1206
     1207!--------------------------------------------------------------------------------------------------!
     1208! Description:
     1209! ------------
     1210!> Read module-specific local restart data arrays (MPI-IO).
     1211!--------------------------------------------------------------------------------------------------!
     1212 SUBROUTINE user_rrd_local_mpi
     1213
     1214!    USE restart_data_mpi_io_mod,                                                                   &
     1215!        ONLY:  rd_mpi_io_check_array, rrd_mpi_io
     1216
     1217!    CALL rd_mpi_io_check_array( 'u2_av' , found = array_found )
     1218!    IF ( array_found )  THEN
     1219!       IF ( .NOT. ALLOCATED( u2_av ) )  ALLOCATE( u2_av(nysg:nyng,nxlg:nxrg) )
     1220!       CALL rrd_mpi_io( 'rad_u2_av', rad_u2_av )
     1221!    ENDIF
     1222
     1223    CONTINUE
     1224
     1225 END SUBROUTINE user_rrd_local_mpi
    11971226
    11981227
     
    12031232!--------------------------------------------------------------------------------------------------!
    12041233 SUBROUTINE user_wrd_global
     1234
     1235!    USE restart_data_mpi_io_mod,                                                                   &
     1236!        ONLY:  wrd_mpi_io
    12051237
    12061238    IF ( TRIM( restart_data_format_output ) == 'fortran_binary' )  THEN
     
    12241256!--------------------------------------------------------------------------------------------------!
    12251257 SUBROUTINE user_wrd_local
     1258
     1259!    USE restart_data_mpi_io_mod,                                                                   &
     1260!        ONLY:  wrd_mpi_io
    12261261
    12271262!
Note: See TracChangeset for help on using the changeset viewer.