[2759] | 1 | !IDEAL:DRIVER_LAYER |
---|
| 2 | ! |
---|
| 3 | ! create an initial data set for the WRF model based on an ideal condition |
---|
| 4 | PROGRAM ideal |
---|
| 5 | |
---|
| 6 | USE module_domain , ONLY : domain |
---|
| 7 | USE module_initialize_ideal |
---|
| 8 | USE module_configure , ONLY : grid_config_rec_type |
---|
| 9 | |
---|
| 10 | USE module_timing |
---|
| 11 | USE module_wrf_error |
---|
| 12 | |
---|
| 13 | IMPLICIT NONE |
---|
| 14 | |
---|
| 15 | REAL :: time |
---|
| 16 | |
---|
| 17 | INTEGER :: loop , & |
---|
| 18 | levels_to_process |
---|
| 19 | |
---|
| 20 | |
---|
| 21 | TYPE(domain) , POINTER :: keep_grid, grid_ptr, null_domain, grid |
---|
| 22 | TYPE(domain) :: dummy |
---|
| 23 | TYPE (grid_config_rec_type) :: config_flags |
---|
| 24 | TYPE (WRFU_Time) startTime, stopTime, currentTime |
---|
| 25 | TYPE (WRFU_TimeInterval) stepTime |
---|
| 26 | |
---|
| 27 | INTEGER :: max_dom , domain_id , fid , oid , idum1 , idum2 , ierr |
---|
| 28 | INTEGER :: debug_level, rc |
---|
| 29 | LOGICAL :: input_from_file |
---|
| 30 | |
---|
| 31 | INTERFACE |
---|
| 32 | SUBROUTINE med_initialdata_output ( grid , config_flags ) |
---|
| 33 | USE module_domain , ONLY : domain |
---|
| 34 | USE module_configure , ONLY : grid_config_rec_type |
---|
| 35 | TYPE (domain) , POINTER :: grid |
---|
| 36 | TYPE (grid_config_rec_type) , INTENT(IN) :: config_flags |
---|
| 37 | END SUBROUTINE med_initialdata_output |
---|
| 38 | END INTERFACE |
---|
| 39 | |
---|
| 40 | #include "version_decl" |
---|
| 41 | |
---|
| 42 | |
---|
| 43 | #ifdef DM_PARALLEL |
---|
| 44 | INTEGER :: nbytes |
---|
| 45 | INTEGER, PARAMETER :: configbuflen = 4* CONFIG_BUF_LEN |
---|
| 46 | INTEGER :: configbuf( configbuflen ) |
---|
| 47 | LOGICAL , EXTERNAL :: wrf_dm_on_monitor |
---|
| 48 | #endif |
---|
| 49 | |
---|
| 50 | CHARACTER (LEN=80) :: message |
---|
| 51 | |
---|
| 52 | ! Define the name of this program (program_name defined in module_domain) |
---|
| 53 | |
---|
| 54 | program_name = "IDEAL " // TRIM(release_version) // " PREPROCESSOR" |
---|
| 55 | |
---|
| 56 | ! Get the NAMELIST data for input. |
---|
| 57 | |
---|
| 58 | CALL init_modules(1) ! Phase 1 returns after MPI_INIT() (if it is called) |
---|
| 59 | CALL WRFU_Initialize( defaultCalendar=WRFU_CAL_GREGORIAN, rc=rc ) |
---|
| 60 | CALL init_modules(2) ! Phase 2 resumes after MPI_INIT() (if it is called) |
---|
| 61 | |
---|
| 62 | #ifdef DM_PARALLEL |
---|
| 63 | IF ( wrf_dm_on_monitor() ) THEN |
---|
| 64 | CALL initial_config |
---|
| 65 | ENDIF |
---|
| 66 | CALL get_config_as_buffer( configbuf, configbuflen, nbytes ) |
---|
| 67 | CALL wrf_dm_bcast_bytes( configbuf, nbytes ) |
---|
| 68 | CALL set_config_as_buffer( configbuf, configbuflen ) |
---|
| 69 | CALL wrf_dm_initialize |
---|
| 70 | #else |
---|
| 71 | CALL initial_config |
---|
| 72 | #endif |
---|
| 73 | CALL nl_get_debug_level ( 1, debug_level ) |
---|
| 74 | CALL set_wrf_debug_level ( debug_level ) |
---|
| 75 | |
---|
| 76 | CALL wrf_message ( program_name ) |
---|
| 77 | |
---|
| 78 | |
---|
| 79 | ! allocated and configure the mother domain |
---|
| 80 | |
---|
| 81 | NULLIFY( null_domain ) |
---|
| 82 | |
---|
| 83 | CALL alloc_and_configure_domain ( domain_id = 1 , & |
---|
| 84 | grid = head_grid , & |
---|
| 85 | parent = null_domain , & |
---|
| 86 | kid = -1 ) |
---|
| 87 | |
---|
| 88 | grid => head_grid |
---|
| 89 | ! TBH: Note that historically, IDEAL did not set up clocks. These |
---|
| 90 | ! TBH: are explicit replacements for old default initializations... They |
---|
| 91 | ! TBH: are needed to ensure that time manager calls do not fail due to |
---|
| 92 | ! TBH: uninitialized clock. Clean this up later... |
---|
| 93 | CALL WRFU_TimeSet(startTime, YY=1, MM=1, DD=1, H=0, M=0, S=0, rc=rc) |
---|
| 94 | stopTime = startTime |
---|
| 95 | currentTime = startTime |
---|
| 96 | ! TBH: Bogus time step value -- clock is never advanced... |
---|
| 97 | CALL WRFU_TimeIntervalSet(stepTime, S=180, rc=rc) |
---|
| 98 | grid%domain_clock = WRFU_ClockCreate( TimeStep= stepTime, & |
---|
| 99 | StartTime=startTime, & |
---|
| 100 | StopTime= stopTime, & |
---|
| 101 | rc=rc ) |
---|
| 102 | CALL wrf_check_error( WRFU_SUCCESS, rc, & |
---|
| 103 | 'grid%domain_clock = WRFU_ClockCreate() FAILED', & |
---|
| 104 | __FILE__ , & |
---|
| 105 | __LINE__ ) |
---|
| 106 | CALL wrf_debug ( 100 , 'wrf: calling model_to_grid_config_rec ' ) |
---|
| 107 | CALL model_to_grid_config_rec ( head_grid%id , model_config_rec , config_flags ) |
---|
| 108 | CALL wrf_debug ( 100 , 'wrf: calling set_scalar_indices_from_config ' ) |
---|
| 109 | CALL set_scalar_indices_from_config ( head_grid%id , idum1, idum2 ) |
---|
| 110 | |
---|
| 111 | #ifdef PLANET |
---|
| 112 | WRITE ( current_date , FMT = '(I4.4,"-",I5.5,"_",I2.2,":",I2.2,":",I2.2,".0000")' ) & |
---|
| 113 | config_flags%start_year, & |
---|
| 114 | config_flags%start_day, & |
---|
| 115 | config_flags%start_hour, & |
---|
| 116 | config_flags%start_minute, & |
---|
| 117 | config_flags%start_second |
---|
| 118 | #else |
---|
| 119 | WRITE ( current_date , FMT = '(I4.4,"-",I2.2,"-",I2.2,"_",I2.2,":",I2.2,":",I2.2,".0000")' ) & |
---|
| 120 | config_flags%start_year, & |
---|
| 121 | config_flags%start_month, & |
---|
| 122 | config_flags%start_day, & |
---|
| 123 | config_flags%start_hour, & |
---|
| 124 | config_flags%start_minute, & |
---|
| 125 | config_flags%start_second |
---|
| 126 | #endif |
---|
| 127 | CALL domain_clockprint ( 150, grid, & |
---|
| 128 | 'DEBUG assemble_output: clock before 1st currTime set,' ) |
---|
| 129 | WRITE (wrf_err_message,*) & |
---|
| 130 | 'DEBUG assemble_output: before 1st currTime set, current_date = ',TRIM(current_date) |
---|
| 131 | CALL wrf_debug ( 150 , wrf_err_message ) |
---|
| 132 | CALL domain_clock_set( grid, current_timestr=current_date(1:19) ) |
---|
| 133 | CALL domain_clockprint ( 150, grid, & |
---|
| 134 | 'DEBUG assemble_output: clock after 1st currTime set,' ) |
---|
| 135 | |
---|
| 136 | CALL wrf_debug ( 100 , 'wrf: calling init_wrfio' ) |
---|
| 137 | CALL init_wrfio |
---|
| 138 | |
---|
| 139 | #ifdef DM_PARALLEL |
---|
| 140 | CALL get_config_as_buffer( configbuf, configbuflen, nbytes ) |
---|
| 141 | CALL wrf_dm_bcast_bytes( configbuf, nbytes ) |
---|
| 142 | CALL set_config_as_buffer( configbuf, configbuflen ) |
---|
| 143 | #endif |
---|
| 144 | |
---|
| 145 | CALL med_initialdata_output( head_grid , config_flags ) |
---|
| 146 | |
---|
| 147 | CALL wrf_debug ( 0 , 'wrf: SUCCESS COMPLETE IDEAL INIT' ) |
---|
| 148 | CALL med_shutdown_io ( head_grid , config_flags ) |
---|
| 149 | CALL wrf_shutdown |
---|
| 150 | |
---|
| 151 | CALL WRFU_Finalize( rc=rc ) |
---|
| 152 | |
---|
| 153 | END PROGRAM ideal |
---|
| 154 | |
---|
| 155 | SUBROUTINE med_initialdata_output ( grid , config_flags ) |
---|
| 156 | ! Driver layer |
---|
| 157 | USE module_domain |
---|
| 158 | USE module_io_domain |
---|
| 159 | USE module_initialize_ideal |
---|
| 160 | ! Model layer |
---|
| 161 | USE module_configure |
---|
| 162 | |
---|
| 163 | IMPLICIT NONE |
---|
| 164 | |
---|
| 165 | ! Arguments |
---|
| 166 | TYPE(domain) , POINTER :: grid |
---|
| 167 | TYPE (grid_config_rec_type) , INTENT(IN) :: config_flags |
---|
| 168 | ! Local |
---|
| 169 | INTEGER :: time_step_begin_restart |
---|
| 170 | INTEGER :: fid , ierr , id |
---|
| 171 | CHARACTER (LEN=80) :: rstname |
---|
| 172 | CHARACTER (LEN=80) :: message |
---|
| 173 | CHARACTER (LEN=80) :: inpname , bdyname |
---|
| 174 | |
---|
| 175 | ! Initialize the mother domain. |
---|
| 176 | |
---|
| 177 | grid%input_from_file = .false. |
---|
| 178 | CALL init_domain ( grid ) |
---|
| 179 | CALL calc_current_date ( grid%id, 0.) |
---|
| 180 | |
---|
| 181 | CALL construct_filename1 ( inpname , 'wrfinput' , grid%id , 2 ) |
---|
| 182 | CALL open_w_dataset ( id, TRIM(inpname) , grid , config_flags , output_model_input , "DATASET=INPUT", ierr ) |
---|
| 183 | IF ( ierr .NE. 0 ) THEN |
---|
| 184 | WRITE (wrf_err_message,*)'ideal: error opening wrfinput for writing ',ierr |
---|
| 185 | CALL wrf_error_fatal( wrf_err_message ) |
---|
| 186 | ENDIF |
---|
| 187 | CALL output_model_input ( id, grid , config_flags , ierr ) |
---|
| 188 | CALL close_dataset ( id , config_flags, "DATASET=INPUT" ) |
---|
| 189 | |
---|
| 190 | |
---|
| 191 | IF ( config_flags%specified ) THEN |
---|
| 192 | |
---|
| 193 | CALL construct_filename1 ( bdyname , 'wrfbdy' , grid%id , 2 ) |
---|
| 194 | CALL open_w_dataset ( id, TRIM(bdyname) , grid , config_flags , output_boundary , "DATASET=BOUNDARY", ierr ) |
---|
| 195 | IF ( ierr .NE. 0 ) THEN |
---|
| 196 | WRITE (wrf_err_message,*)'ideal: error opening wrfbdy for writing ',ierr |
---|
| 197 | CALL wrf_error_fatal( wrf_err_message ) |
---|
| 198 | ENDIF |
---|
| 199 | CALL output_boundary ( id, grid , config_flags , ierr ) |
---|
| 200 | CALL close_dataset ( id , config_flags , "DATASET=BOUNDARY" ) |
---|
| 201 | |
---|
| 202 | ENDIF |
---|
| 203 | |
---|
| 204 | RETURN |
---|
| 205 | END SUBROUTINE med_initialdata_output |
---|
| 206 | |
---|