source: trunk/WRF.COMMON/WRFV3/main/ideal.F @ 3568

Last change on this file since 3568 was 2759, checked in by aslmd, 3 years ago

adding unmodified code from WRFV3.0.1.1, expurged from useless data +1M size

File size: 7.1 KB
Line 
1!IDEAL:DRIVER_LAYER
2!
3! create an initial data set for the WRF model based on an ideal condition
4PROGRAM 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
153END PROGRAM ideal
154
155SUBROUTINE 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
205END SUBROUTINE med_initialdata_output
206
Note: See TracBrowser for help on using the repository browser.