Line data Source code
1 : !=======================================================================
2 : !
3 : ! This module contains the Icepack initialization routine that sets model
4 : ! parameters and initializes the grid and state variables.
5 : !
6 : ! authors Elizabeth C. Hunke, LANL
7 :
8 : module icedrv_InitMod
9 :
10 : use icedrv_kinds
11 : use icedrv_constants, only: nu_diag
12 : use icepack_intfc, only: icepack_warnings_flush, icepack_warnings_aborted
13 : use icepack_intfc, only: icepack_query_parameters, icepack_query_tracer_flags
14 : use icepack_intfc, only: icepack_write_tracer_flags, icepack_write_tracer_indices
15 : use icepack_intfc, only: icepack_write_tracer_sizes
16 : use icedrv_system, only: icedrv_system_abort
17 :
18 : implicit none
19 : private
20 : public :: icedrv_initialize
21 :
22 : !=======================================================================
23 :
24 : contains
25 :
26 : !=======================================================================
27 :
28 :
29 : ! Initialize Icepack
30 :
31 46 : subroutine icedrv_initialize
32 :
33 : use icedrv_arrays_column, only: hin_max, c_hi_range
34 : use icedrv_arrays_column, only: floe_rad_l, floe_rad_c, &
35 : floe_binwidth, c_fsd_range
36 : use icedrv_calendar, only: dt, time, istep, istep1, &
37 : init_calendar, calendar
38 : use icepack_intfc, only: icepack_init_itd, icepack_init_itd_hist
39 : use icepack_intfc, only: icepack_init_fsd_bounds
40 : use icepack_intfc, only: icepack_warnings_flush
41 : use icedrv_domain_size, only: ncat, nfsd
42 : ! use icedrv_diagnostics, only: icedrv_diagnostics_debug
43 : use icedrv_flux, only: init_coupler_flux, init_history_therm, &
44 : init_flux_atm_ocn
45 : use icedrv_forcing, only: init_forcing, get_forcing, get_wave_spec
46 : use icedrv_forcing_bgc, only: get_forcing_bgc, faero_default, fiso_default, init_forcing_bgc
47 : use icedrv_restart_shared, only: restart
48 : use icedrv_init, only: input_data, init_state, init_grid2, init_fsd
49 : use icedrv_init_column, only: init_thermo_vertical, init_shortwave, init_zbgc
50 : use icepack_intfc, only: icepack_configure
51 :
52 : logical (kind=log_kind) :: &
53 : skl_bgc, & ! from icepack
54 : z_tracers, & ! from icepack
55 : tr_aero, & ! from icepack
56 : tr_iso, & ! from icepack
57 : tr_zaero, & ! from icepack
58 : tr_fsd, wave_spec
59 :
60 : character(len=*), parameter :: subname='(icedrv_initialize)'
61 :
62 46 : call icepack_configure() ! initialize icepack
63 46 : call icepack_warnings_flush(nu_diag)
64 46 : if (icepack_warnings_aborted()) call icedrv_system_abort(string=subname, &
65 0 : file=__FILE__,line= __LINE__)
66 :
67 46 : call input_data ! namelist variables
68 46 : call init_zbgc ! vertical biogeochemistry namelist
69 :
70 : ! generate some output
71 46 : call icepack_write_tracer_flags(nu_diag)
72 46 : call icepack_write_tracer_sizes(nu_diag)
73 46 : call icepack_write_tracer_indices(nu_diag)
74 46 : call icepack_warnings_flush(nu_diag)
75 46 : if (icepack_warnings_aborted()) call icedrv_system_abort(string=subname, &
76 0 : file=__FILE__,line= __LINE__)
77 :
78 46 : call init_grid2 ! grid variables
79 46 : call init_calendar ! initialize some calendar stuff
80 46 : call init_coupler_flux ! initialize fluxes exchanged with coupler
81 46 : call init_thermo_vertical ! initialize vertical thermodynamics
82 46 : call icepack_init_itd(ncat=ncat, hin_max=hin_max)
83 :
84 46 : call icepack_warnings_flush(nu_diag)
85 46 : if (icepack_warnings_aborted(subname)) then
86 0 : call icedrv_system_abort(file=__FILE__,line=__LINE__)
87 : endif
88 :
89 46 : call icepack_init_itd_hist(ncat=ncat, c_hi_range=c_hi_range, hin_max=hin_max) ! output
90 :
91 46 : call icepack_query_tracer_flags(tr_fsd_out=tr_fsd)
92 46 : call icepack_warnings_flush(nu_diag)
93 46 : if (icepack_warnings_aborted(subname)) then
94 0 : call icedrv_system_abort(file=__FILE__,line=__LINE__)
95 : endif
96 :
97 46 : if (tr_fsd) then
98 : call icepack_init_fsd_bounds( &
99 : nfsd=nfsd, & ! floe size distribution
100 : floe_rad_l=floe_rad_l, & ! fsd size lower bound in m (radius)
101 : floe_rad_c=floe_rad_c, & ! fsd size bin centre in m (radius)
102 : floe_binwidth=floe_binwidth, & ! fsd size bin width in m (radius)
103 4 : c_fsd_range=c_fsd_range) ! string for history output
104 4 : call icepack_warnings_flush(nu_diag)
105 4 : if (icepack_warnings_aborted(subname)) then
106 0 : call icedrv_system_abort(file=__FILE__,line=__LINE__)
107 : endif
108 : endif
109 46 : call init_fsd
110 :
111 46 : call calendar(time) ! determine the initial date
112 :
113 46 : call init_state ! initialize the ice state
114 46 : call init_restart ! initialize restart variables
115 46 : call init_history_therm ! initialize thermo history variables
116 :
117 46 : if (restart) &
118 15 : call init_shortwave ! initialize radiative transfer
119 :
120 46 : istep = istep + 1 ! update time step counters
121 46 : istep1 = istep1 + 1
122 46 : time = time + dt ! determine the time and date
123 46 : call calendar(time) ! at the end of the first timestep
124 :
125 : !--------------------------------------------------------------------
126 : ! coupler communication or forcing data initialization
127 : !--------------------------------------------------------------------
128 46 : call icepack_query_parameters(skl_bgc_out=skl_bgc)
129 46 : call icepack_query_parameters(z_tracers_out=z_tracers)
130 46 : call icepack_query_parameters(wave_spec_out=wave_spec)
131 46 : call icepack_query_tracer_flags(tr_aero_out=tr_aero)
132 46 : call icepack_query_tracer_flags(tr_iso_out=tr_iso)
133 46 : call icepack_query_tracer_flags(tr_zaero_out=tr_zaero)
134 46 : call icepack_warnings_flush(nu_diag)
135 46 : if (icepack_warnings_aborted()) call icedrv_system_abort(string=subname, &
136 0 : file=__FILE__,line= __LINE__)
137 :
138 46 : call init_forcing ! initialize forcing (standalone)
139 46 : if (skl_bgc .or. z_tracers) call init_forcing_bgc !cn
140 46 : if (tr_fsd .and. wave_spec) call get_wave_spec ! wave spectrum in ice
141 46 : call get_forcing(istep1) ! get forcing from data arrays
142 :
143 46 : if (tr_iso) call fiso_default ! default values
144 : ! aerosols
145 : ! if (tr_aero) call faero_data ! data file
146 : ! if (tr_zaero) call fzaero_data ! data file (gx1)
147 46 : if (tr_aero .or. tr_zaero) call faero_default ! default values
148 46 : if (skl_bgc .or. z_tracers) call get_forcing_bgc ! biogeochemistry
149 :
150 46 : if (.not. restart) &
151 31 : call init_shortwave ! initialize radiative transfer using current swdn
152 :
153 46 : call init_flux_atm_ocn ! initialize atmosphere, ocean fluxes
154 :
155 46 : end subroutine icedrv_initialize
156 :
157 : !=======================================================================
158 :
159 46 : subroutine init_restart
160 :
161 : use icedrv_calendar, only: time, calendar
162 : use icepack_intfc, only: icepack_aggregate
163 : use icedrv_domain_size, only: ncat, max_ntrcr, nx
164 : use icedrv_init, only: ice_ic
165 : use icedrv_init, only: tmask
166 : use icedrv_init_column, only: init_hbrine, init_bgc
167 : use icedrv_restart, only: restartfile
168 : use icedrv_restart_shared, only: restart
169 : use icedrv_restart_bgc, only: read_restart_bgc
170 : use icedrv_state ! almost everything
171 :
172 : integer(kind=int_kind) :: &
173 : i ! horizontal indices
174 :
175 : logical (kind=log_kind) :: &
176 : skl_bgc, & ! from icepack
177 : z_tracers, & ! from icepack
178 : solve_zsal, & ! from icepack
179 : tr_brine, & ! from icepack
180 : tr_fsd ! from icepack
181 :
182 : character(len=*), parameter :: subname='(init_restart)'
183 :
184 : !-----------------------------------------------------------------
185 : ! query Icepack values
186 : !-----------------------------------------------------------------
187 :
188 46 : call icepack_query_parameters(skl_bgc_out=skl_bgc)
189 46 : call icepack_query_parameters(z_tracers_out=z_tracers)
190 46 : call icepack_query_parameters(solve_zsal_out=solve_zsal)
191 46 : call icepack_query_tracer_flags(tr_brine_out=tr_brine, tr_fsd_out=tr_fsd)
192 46 : call icepack_warnings_flush(nu_diag)
193 46 : if (icepack_warnings_aborted()) call icedrv_system_abort(string=subname, &
194 0 : file=__FILE__,line= __LINE__)
195 :
196 : !-----------------------------------------------------------------
197 :
198 46 : if (tr_brine .or. skl_bgc) then ! brine height tracer
199 5 : call init_hbrine
200 : endif
201 :
202 46 : if (restart) then
203 15 : call restartfile (ice_ic)
204 15 : call calendar (time)
205 : endif
206 :
207 46 : if (solve_zsal .or. skl_bgc .or. z_tracers) then
208 5 : if (tr_fsd) then
209 0 : write (nu_diag,*) 'FSD implementation incomplete for use with BGC'
210 0 : call icedrv_system_abort(string=subname,file=__FILE__,line=__LINE__)
211 : endif
212 5 : call init_bgc
213 5 : if (restart) call read_restart_bgc ! complete BGC initialization
214 : endif
215 :
216 : !-----------------------------------------------------------------
217 : ! aggregate tracers
218 : !-----------------------------------------------------------------
219 230 : do i = 1, nx
220 184 : if (tmask(i)) &
221 : call icepack_aggregate(ncat=ncat, &
222 : aicen=aicen(i,:), &
223 : vicen=vicen(i,:), &
224 : vsnon=vsnon(i,:), &
225 : trcrn=trcrn(i,:,:), &
226 51 : aice=aice (i), &
227 51 : vice=vice (i), &
228 51 : vsno=vsno (i), &
229 : trcr=trcr (i,:), &
230 51 : aice0=aice0(i), &
231 : ntrcr=max_ntrcr, &
232 : trcr_depend=trcr_depend, &
233 : trcr_base=trcr_base, &
234 : n_trcr_strata=n_trcr_strata, &
235 286 : nt_strata=nt_strata)
236 : enddo
237 46 : call icepack_warnings_flush(nu_diag)
238 46 : if (icepack_warnings_aborted()) call icedrv_system_abort(string=subname, &
239 0 : file=__FILE__, line=__LINE__)
240 :
241 46 : end subroutine init_restart
242 :
243 : !=======================================================================
244 :
245 : end module icedrv_InitMod
246 :
247 : !=======================================================================
|