1 | MODULE limdia |
---|
2 | !!====================================================================== |
---|
3 | !! *** MODULE limdia *** |
---|
4 | !! LIM-3 sea ice model : diagnostics of ice model |
---|
5 | !!====================================================================== |
---|
6 | !! History : 3.2 ! 2007-01 (M. Vancoppenolle) Code adapted from LIM-2 |
---|
7 | !! - ! 2008-03 (M. Vancoppenolle) add lim_dia_init |
---|
8 | !!---------------------------------------------------------------------- |
---|
9 | #if defined key_lim3 |
---|
10 | !!---------------------------------------------------------------------- |
---|
11 | !! 'key_lim3' LIM3 sea-ice model |
---|
12 | !!---------------------------------------------------------------------- |
---|
13 | !! lim_dia : computation and output of the time evolution of keys variables |
---|
14 | !! lim_dia_init : initialization and namelist read |
---|
15 | !!---------------------------------------------------------------------- |
---|
16 | USE ice ! LIM-3: sea-ice variable |
---|
17 | USE par_ice ! LIM-3: ice parameters |
---|
18 | USE dom_ice ! LIM-3: sea-ice domain |
---|
19 | USE dom_oce ! ocean domain |
---|
20 | USE sbc_oce ! surface boundary condition: ocean fields |
---|
21 | USE daymod ! model calendar |
---|
22 | USE phycst ! physical constant |
---|
23 | USE in_out_manager ! I/O manager |
---|
24 | USE lib_mpp ! MPP library |
---|
25 | USE lib_fortran ! Fortran utilities (allows no signed zero when 'key_nosignedzero' defined) |
---|
26 | |
---|
27 | IMPLICIT NONE |
---|
28 | PRIVATE |
---|
29 | |
---|
30 | PUBLIC lim_dia ! called by ice_step |
---|
31 | |
---|
32 | INTEGER, PUBLIC :: ntmoy = 1 !: instantaneous values of ice evolution or averaging ntmoy |
---|
33 | INTEGER, PUBLIC :: ninfo = 1 !: frequency of ouputs on file ice_evolu in case of averaging |
---|
34 | |
---|
35 | ! !!! Parameters for outputs to files "evolu" |
---|
36 | INTEGER, PARAMETER :: jpinfmx = 100 ! maximum number of key variables |
---|
37 | INTEGER, PARAMETER :: jpchinf = 5 ! ??? |
---|
38 | INTEGER, PARAMETER :: jpchsep = jpchinf + 2 ! ??? |
---|
39 | |
---|
40 | INTEGER :: nfrinf = 4 ! number of variables written in one line |
---|
41 | INTEGER :: nferme ! last time step at which the var. are written on file |
---|
42 | INTEGER :: nvinfo ! number of total variables |
---|
43 | INTEGER :: nbvt ! number of time variables |
---|
44 | INTEGER :: naveg ! number of step for accumulation before averaging |
---|
45 | REAL(wp) :: epsi06 = 1.e-6_wp ! small number |
---|
46 | |
---|
47 | CHARACTER(len= 8) :: fmtinf = '1PE13.5 ' ! format of the output values |
---|
48 | CHARACTER(len=30) :: fmtw ! formats |
---|
49 | CHARACTER(len=30) :: fmtr ! ??? |
---|
50 | CHARACTER(len=30) :: fmtitr ! ??? |
---|
51 | |
---|
52 | CHARACTER(len=jpchsep), DIMENSION(jpinfmx) :: titvar ! title of key variables |
---|
53 | |
---|
54 | REAL(wp), DIMENSION(jpinfmx) :: vinfom ! temporary working space |
---|
55 | REAL(wp), ALLOCATABLE, SAVE, DIMENSION(:,:) :: aire ! masked grid cell area |
---|
56 | |
---|
57 | !! * Substitutions |
---|
58 | # include "vectopt_loop_substitute.h90" |
---|
59 | !!---------------------------------------------------------------------- |
---|
60 | !! NEMO/LIM3 3.3 , UCL - NEMO Consortium (2010) |
---|
61 | !! $Id$ |
---|
62 | !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt) |
---|
63 | !!---------------------------------------------------------------------- |
---|
64 | CONTAINS |
---|
65 | |
---|
66 | SUBROUTINE lim_dia |
---|
67 | !!-------------------------------------------------------------------- |
---|
68 | !! *** ROUTINE lim_dia *** |
---|
69 | !! |
---|
70 | !! ** Purpose : Computation and outputs on file ice.evolu |
---|
71 | !! the temporal evolution of some key variables |
---|
72 | !!------------------------------------------------------------------- |
---|
73 | INTEGER :: jv, ji, jj, jl ! dummy loop indices |
---|
74 | REAL(wp) :: zshift_date ! date from the minimum ice extent |
---|
75 | REAL(wp) :: zday, zday_min ! current day, day of minimum extent |
---|
76 | REAL(wp) :: zafy, zamy ! temporary area of fy and my ice |
---|
77 | REAL(wp) :: zindb |
---|
78 | REAL(wp), DIMENSION(jpinfmx) :: vinfor ! temporary working space |
---|
79 | !!------------------------------------------------------------------- |
---|
80 | |
---|
81 | ! 0) date from the minimum of ice extent |
---|
82 | !--------------------------------------- |
---|
83 | zday_min = 273._wp ! zday_min = date of minimum extent, here September 30th |
---|
84 | zday = REAL(numit-nit000,wp) * rdt_ice / ( 86400._wp * REAL(nn_fsbc,wp) ) |
---|
85 | ! |
---|
86 | IF( zday > zday_min ) THEN ; zshift_date = zday - zday_min |
---|
87 | ELSE ; zshift_date = zday - (365.0 - zday_min) |
---|
88 | ENDIF |
---|
89 | |
---|
90 | IF( numit == nstart ) CALL lim_dia_init ! initialisation of ice_evolu file |
---|
91 | |
---|
92 | vinfor(1) = REAL(numit) ! time diagnostics |
---|
93 | vinfor(2) = nyear |
---|
94 | |
---|
95 | DO jv = nbvt + 1, nvinfo ! put everything to zero |
---|
96 | vinfor(jv) = 0._wp |
---|
97 | END DO |
---|
98 | |
---|
99 | !!------------------------------------------------------------------- |
---|
100 | !! 1) Northern hemisphere |
---|
101 | !!------------------------------------------------------------------- |
---|
102 | !! 1.1) Diagnostics independent on age |
---|
103 | !!------------------------------------ |
---|
104 | DO jj = njeq, jpjm1 |
---|
105 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
106 | IF( tms(ji,jj) == 1 ) THEN |
---|
107 | vinfor(3) = vinfor(3) + at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !ice area |
---|
108 | IF ( at_i(ji,jj) > 0.15 ) vinfor(5) = vinfor(5) + aire(ji,jj) * 1.e-12_wp !ice extent |
---|
109 | vinfor(7) = vinfor(7) + vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
110 | vinfor(9) = vinfor(9) + vt_s(ji,jj)*aire(ji,jj) * 1.e-12_wp !snow volume |
---|
111 | vinfor(15) = vinfor(15) + ot_i(ji,jj) *vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !mean age |
---|
112 | vinfor(29) = vinfor(29) + smt_i(ji,jj)*vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !mean salinity |
---|
113 | ! the computation of this diagnostic is not reliable |
---|
114 | vinfor(31) = vinfor(31) + vt_i(ji,jj) * ( u_ice(ji,jj)*u_ice(ji,jj) & |
---|
115 | & + v_ice(ji,jj)*v_ice(ji,jj) ) * aire(ji,jj) * 1.e-12 |
---|
116 | vinfor(53) = vinfor(53) + sfx (ji,jj)*aire(ji,jj) * 1.e-12_wp !salt flux |
---|
117 | vinfor(55) = vinfor(55) + sfx_bri(ji,jj)*aire(ji,jj) * 1.e-12_wp !brine drainage flux |
---|
118 | vinfor(57) = vinfor(57) + sfx_thd(ji,jj)*aire(ji,jj) * 1.e-12_wp !equivalent salt flux |
---|
119 | vinfor(59) = vinfor(59) +(sst_m(ji,jj)+rt0)*at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !SST |
---|
120 | vinfor(61) = vinfor(61) + sss_m(ji,jj)*at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !SSS |
---|
121 | vinfor(65) = vinfor(65) + et_s(ji,jj)/1.0e9*aire(ji,jj) * 1.e-12_wp ! snow temperature |
---|
122 | vinfor(67) = vinfor(67) + et_i(ji,jj)/1.0e9*aire(ji,jj) * 1.e-12_wp ! ice heat content |
---|
123 | vinfor(69) = vinfor(69) + v_i(ji,jj,1)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
124 | vinfor(71) = vinfor(71) + v_i(ji,jj,2)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
125 | vinfor(73) = vinfor(73) + v_i(ji,jj,3)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
126 | vinfor(75) = vinfor(75) + v_i(ji,jj,4)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
127 | vinfor(77) = vinfor(77) + v_i(ji,jj,5)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
128 | vinfor(79) = 0.0 |
---|
129 | vinfor(81) = vinfor(81) + emp(ji,jj)*aire(ji,jj) * 1.e-12_wp ! mass flux |
---|
130 | ENDIF |
---|
131 | END DO |
---|
132 | END DO |
---|
133 | |
---|
134 | DO jl = ice_cat_bounds(1,1), ice_cat_bounds(1,2) |
---|
135 | DO jj = njeq, jpjm1 |
---|
136 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
137 | IF( tms(ji,jj) == 1 ) THEN |
---|
138 | vinfor(11) = vinfor(11) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !undef def ice volume |
---|
139 | ENDIF |
---|
140 | END DO |
---|
141 | END DO |
---|
142 | END DO |
---|
143 | |
---|
144 | vinfor(13) = 0._wp |
---|
145 | |
---|
146 | vinfor(15) = vinfor(15) / MAX(vinfor(7),epsi06) ! these have to be divided by total ice volume to have the |
---|
147 | vinfor(29) = vinfor(29) / MAX(vinfor(7),epsi06) ! right value |
---|
148 | vinfor(31) = SQRT( vinfor(31) / MAX( vinfor(7) , epsi06 ) ) |
---|
149 | vinfor(67) = vinfor(67) / MAX(vinfor(7),epsi06) |
---|
150 | |
---|
151 | vinfor(53) = vinfor(53) / MAX(vinfor(5),epsi06) ! these have to be divided by total ice extent to have the |
---|
152 | vinfor(55) = vinfor(55) / MAX(vinfor(5),epsi06) ! right value |
---|
153 | vinfor(57) = vinfor(57) / MAX(vinfor(5),epsi06) ! |
---|
154 | vinfor(79) = vinfor(79) / MAX(vinfor(5),epsi06) ! |
---|
155 | |
---|
156 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(3))) ! |
---|
157 | vinfor(59) = zindb*vinfor(59) / MAX(vinfor(3),epsi06) ! divide by ice area |
---|
158 | vinfor(61) = zindb*vinfor(61) / MAX(vinfor(3),epsi06) ! |
---|
159 | |
---|
160 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(9))) ! |
---|
161 | vinfor(65) = zindb*vinfor(65) / MAX(vinfor(9),epsi06) ! divide it by snow volume |
---|
162 | |
---|
163 | |
---|
164 | DO jl = 1, jpl |
---|
165 | DO jj = njeq, jpjm1 |
---|
166 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
167 | IF( tms(ji,jj) == 1 ) THEN |
---|
168 | vinfor(33) = vinfor(33) + d_v_i_trp(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
169 | vinfor(35) = vinfor(35) + d_v_i_thd(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
170 | ENDIF |
---|
171 | END DO |
---|
172 | END DO |
---|
173 | END DO |
---|
174 | |
---|
175 | DO jj = njeq, jpjm1 |
---|
176 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
177 | IF( tms(ji,jj) == 1 ) THEN |
---|
178 | vinfor(37) = vinfor(37) + diag_sni_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp !th growth rates |
---|
179 | vinfor(39) = vinfor(39) + diag_lat_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
180 | vinfor(41) = vinfor(41) + diag_bot_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
181 | vinfor(43) = vinfor(43) + diag_dyn_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
182 | vinfor(45) = vinfor(45) + dv_dt_thd(ji,jj,5)*aire(ji,jj) * 1.e-12_wp |
---|
183 | vinfor(47) = vinfor(47) + v_newice(ji,jj) *aire(ji,jj) * 1.e-12_wp * r1_rdtice ! volume acc in OW |
---|
184 | ENDIF |
---|
185 | END DO |
---|
186 | END DO |
---|
187 | |
---|
188 | DO jl = 1, jpl |
---|
189 | DO jj = njeq, jpjm1 |
---|
190 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
191 | IF( tms(ji,jj) == 1 ) THEN |
---|
192 | vinfor(63) = vinfor(63) + t_su(ji,jj,jl)*a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp |
---|
193 | ENDIF |
---|
194 | END DO |
---|
195 | END DO |
---|
196 | END DO |
---|
197 | vinfor(63) = vinfor(63) / MAX(vinfor(3),epsi06) ! these have to be divided by total ice area |
---|
198 | |
---|
199 | !! 1.2) Diagnostics dependent on age |
---|
200 | !!------------------------------------ |
---|
201 | DO jj = njeq, jpjm1 |
---|
202 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
203 | IF( tms(ji,jj) == 1 ) THEN |
---|
204 | zafy = 0.0 |
---|
205 | zamy = 0.0 |
---|
206 | DO jl = 1, jpl |
---|
207 | IF ((o_i(ji,jj,jl) - zshift_date).LT.0.0) THEN |
---|
208 | vinfor(17) = vinfor(17) + a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! FY ice area |
---|
209 | vinfor(25) = vinfor(25) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! FY ice volume |
---|
210 | vinfor(49) = vinfor(49) + sm_i(ji,jj,jl)*v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !FY ice salinity |
---|
211 | zafy = zafy + a_i(ji,jj,jl) |
---|
212 | ENDIF |
---|
213 | IF ((o_i(ji,jj,jl) - zshift_date).GT.0.0) THEN |
---|
214 | vinfor(19) = vinfor(19) + a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! MY ice area |
---|
215 | vinfor(27) = vinfor(27) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! MY ice volume |
---|
216 | vinfor(51) = vinfor(51) + sm_i(ji,jj,jl)*v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !MY ice salinity |
---|
217 | zamy = zamy + a_i(ji,jj,jl) |
---|
218 | ENDIF |
---|
219 | END DO |
---|
220 | IF ((at_i(ji,jj).GT.0.15).AND.(zafy.GT.zamy)) THEN |
---|
221 | vinfor(21) = vinfor(21) + aire(ji,jj) * 1.e-12_wp ! Seasonal ice extent |
---|
222 | ENDIF |
---|
223 | IF ((at_i(ji,jj).GT.0.15).AND.(zafy.LE.zamy)) THEN |
---|
224 | vinfor(23) = vinfor(23) + aire(ji,jj) * 1.e-12_wp ! Perennial ice extent |
---|
225 | ENDIF |
---|
226 | ENDIF |
---|
227 | END DO |
---|
228 | END DO |
---|
229 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(25))) !=0 if no multiyear ice 1 if yes |
---|
230 | vinfor(49) = zindb*vinfor(49) / MAX(vinfor(25),epsi06) |
---|
231 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(27))) !=0 if no multiyear ice 1 if yes |
---|
232 | vinfor(51) = zindb*vinfor(51) / MAX(vinfor(27),epsi06) |
---|
233 | |
---|
234 | !! Fram Strait Export |
---|
235 | !!gm BUG : hard coded ORCA2 case !!! ===>>>> to be removed !!!! |
---|
236 | !!gm moreover, this is NOT the correct way of evaluating a ice transport ! |
---|
237 | !!gm mass of snow + ice is missing and a j, j+1 is also missing |
---|
238 | !!gm BUG in MPP case ! |
---|
239 | !! 83 = area export |
---|
240 | !! 84 = volume export |
---|
241 | !! Fram strait in ORCA2 = 5 points |
---|
242 | !! export = -v_ice*e1t*ddtb*at_i or -v_ice*e1t*ddtb*at_i*h_i |
---|
243 | jj = 136 ! C grid |
---|
244 | vinfor(83) = 0.0 |
---|
245 | vinfor(84) = 0.0 |
---|
246 | DO ji = 134, 138 |
---|
247 | vinfor(83) = vinfor(83) - v_ice(ji,jj) * e1t(ji,jj)*at_i(ji,jj)*rdt_ice * 1.e-12_wp |
---|
248 | vinfor(84) = vinfor(84) - v_ice(ji,jj) * e1t(ji,jj)*vt_i(ji,jj)*rdt_ice * 1.e-12_wp |
---|
249 | END DO |
---|
250 | !!gm en BUG |
---|
251 | |
---|
252 | !!------------------------------------------------------------------- |
---|
253 | !! 2) Southern hemisphere |
---|
254 | !!------------------------------------------------------------------- |
---|
255 | !! 2.1) Diagnostics independent on age |
---|
256 | !!------------------------------------ |
---|
257 | DO jj = 2, njeqm1 |
---|
258 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
259 | IF( tms(ji,jj) == 1 ) THEN |
---|
260 | vinfor(4) = vinfor(4) + at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !ice area |
---|
261 | IF (at_i(ji,jj).GT.0.15) vinfor(6) = vinfor(6) + aire(ji,jj) * 1.e-12_wp !ice extent |
---|
262 | vinfor(8) = vinfor(8) + vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
263 | vinfor(10) = vinfor(10) + vt_s(ji,jj)*aire(ji,jj) * 1.e-12_wp !snow volume |
---|
264 | vinfor(16) = vinfor(16) + ot_i(ji,jj)*vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !mean age |
---|
265 | vinfor(30) = vinfor(30) + smt_i(ji,jj)*vt_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !mean salinity |
---|
266 | ! this diagnostic is not well computed (weighted by vol instead |
---|
267 | ! of area) |
---|
268 | vinfor(32) = vinfor(32) + vt_i(ji,jj)*( u_ice(ji,jj)*u_ice(ji,jj) + & |
---|
269 | v_ice(ji,jj)*v_ice(ji,jj) )*aire(ji,jj)/1.0e12 !ice vel |
---|
270 | vinfor(54) = vinfor(54) + sfx (ji,jj)*aire(ji,jj) * 1.e-12_wp ! Total salt flux |
---|
271 | vinfor(56) = vinfor(56) + sfx_bri(ji,jj)*aire(ji,jj) * 1.e-12_wp ! Brine drainage salt flux |
---|
272 | vinfor(58) = vinfor(58) + sfx_thd(ji,jj)*aire(ji,jj) * 1.e-12_wp ! Equivalent salt flux |
---|
273 | vinfor(60) = vinfor(60) +(sst_m(ji,jj)+rt0)*at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !SST |
---|
274 | vinfor(62) = vinfor(62) + sss_m(ji,jj)*at_i(ji,jj)*aire(ji,jj) * 1.e-12_wp !SSS |
---|
275 | vinfor(66) = vinfor(66) + et_s(ji,jj)/1.0e9*aire(ji,jj) * 1.e-12_wp ! snow temperature |
---|
276 | vinfor(68) = vinfor(68) + et_i(ji,jj)/1.0e9*aire(ji,jj) * 1.e-12_wp ! ice enthalpy |
---|
277 | vinfor(70) = vinfor(70) + v_i(ji,jj,1)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
278 | vinfor(72) = vinfor(72) + v_i(ji,jj,2)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
279 | vinfor(74) = vinfor(74) + v_i(ji,jj,3)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
280 | vinfor(76) = vinfor(76) + v_i(ji,jj,4)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
281 | vinfor(78) = vinfor(78) + v_i(ji,jj,5)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
282 | vinfor(80) = 0.0 |
---|
283 | vinfor(82) = vinfor(82) + emp(ji,jj)*aire(ji,jj) * 1.e-12_wp ! mass flux |
---|
284 | ENDIF |
---|
285 | END DO |
---|
286 | END DO |
---|
287 | |
---|
288 | DO jl = ice_cat_bounds(1,1), ice_cat_bounds(1,2) |
---|
289 | DO jj = 2, njeqm1 |
---|
290 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
291 | vinfor(12) = vinfor(12) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !undef def ice volume |
---|
292 | END DO |
---|
293 | END DO |
---|
294 | END DO |
---|
295 | |
---|
296 | vinfor(14) = 0.0 |
---|
297 | |
---|
298 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(8))) |
---|
299 | vinfor(16) = zindb * vinfor(16) / MAX(vinfor(8),epsi06) ! these have to be divided by ice vol |
---|
300 | vinfor(30) = zindb * vinfor(30) / MAX(vinfor(8),epsi06) ! |
---|
301 | vinfor(32) = zindb * SQRT( vinfor(32) / MAX( vinfor(8) , epsi06 ) ) |
---|
302 | vinfor(68) = zindb * vinfor(68) / MAX(vinfor(8),epsi06) ! |
---|
303 | |
---|
304 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(6))) |
---|
305 | vinfor(54) = zindb * vinfor(54) / MAX(vinfor(6),epsi06) ! these have to be divided by ice extt |
---|
306 | vinfor(56) = zindb * vinfor(56) / MAX(vinfor(6),epsi06) ! |
---|
307 | vinfor(58) = zindb * vinfor(58) / MAX(vinfor(6),epsi06) ! |
---|
308 | vinfor(80) = zindb * vinfor(80) / MAX(vinfor(6),epsi06) ! |
---|
309 | ! vinfor(84) = vinfor(84) / vinfor(6) ! |
---|
310 | |
---|
311 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(4))) ! |
---|
312 | vinfor(60) = zindb*vinfor(60) / ( MAX(vinfor(4), epsi06) ) ! divide by ice area |
---|
313 | vinfor(62) = zindb*vinfor(62) / ( MAX(vinfor(4), epsi06) ) ! |
---|
314 | |
---|
315 | zindb = 1.0 - MAX(0.0,SIGN(1.0,-vinfor(10))) ! |
---|
316 | vinfor(66) = zindb*vinfor(66) / MAX(vinfor(10),epsi06) ! divide it by snow volume |
---|
317 | |
---|
318 | DO jl = 1, jpl |
---|
319 | DO jj = 2, njeqm1 |
---|
320 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
321 | IF( tms(ji,jj) == 1 ) THEN |
---|
322 | vinfor(34) = vinfor(34) + d_v_i_trp(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
323 | vinfor(36) = vinfor(36) + d_v_i_thd(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !ice volume |
---|
324 | ENDIF |
---|
325 | END DO |
---|
326 | END DO |
---|
327 | END DO |
---|
328 | |
---|
329 | DO jj = 2, njeqm1 |
---|
330 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
331 | IF( tms(ji,jj) == 1 ) THEN |
---|
332 | vinfor(38) = vinfor(38) + diag_sni_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp !th growth rates |
---|
333 | vinfor(40) = vinfor(40) + diag_lat_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
334 | vinfor(42) = vinfor(42) + diag_bot_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
335 | vinfor(44) = vinfor(44) + diag_dyn_gr(ji,jj)*aire(ji,jj) * 1.e-12_wp |
---|
336 | vinfor(46) = vinfor(46) + dv_dt_thd(ji,jj,5)*aire(ji,jj) * 1.e-12_wp |
---|
337 | vinfor(48) = vinfor(48) + v_newice(ji,jj) *aire(ji,jj) * 1.e-12_wp * r1_rdtice ! volume acc in OW |
---|
338 | ENDIF |
---|
339 | END DO |
---|
340 | END DO |
---|
341 | |
---|
342 | DO jl = 1, jpl |
---|
343 | DO jj = 2, njeqm1 |
---|
344 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
345 | IF( tms(ji,jj) == 1 ) THEN |
---|
346 | vinfor(64) = vinfor(64) + t_su(ji,jj,jl)*a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp |
---|
347 | ENDIF |
---|
348 | END DO |
---|
349 | END DO |
---|
350 | END DO |
---|
351 | zindb = 1._wp - MAX( 0._wp , SIGN( 1._wp , -vinfor(4) ) ) ! |
---|
352 | vinfor(64) = zindb * vinfor(64) / MAX( vinfor(4) , epsi06 ) ! divide by ice extt |
---|
353 | !! 2.2) Diagnostics dependent on age |
---|
354 | !!------------------------------------ |
---|
355 | DO jj = 2, njeqm1 |
---|
356 | DO ji = fs_2, fs_jpim1 ! vector opt. |
---|
357 | IF( tms(ji,jj) == 1 ) THEN |
---|
358 | zafy = 0._wp |
---|
359 | zamy = 0._wp |
---|
360 | DO jl = 1, jpl |
---|
361 | IF( (o_i(ji,jj,jl) - zshift_date) < 0._wp ) THEN |
---|
362 | vinfor(18) = vinfor(18) + a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! FY ice area |
---|
363 | vinfor(26) = vinfor(26) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! FY ice volume |
---|
364 | zafy = zafy + a_i(ji,jj,jl) |
---|
365 | vinfor(50) = vinfor(50) + sm_i(ji,jj,jl)*v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !FY ice salinity |
---|
366 | ENDIF |
---|
367 | IF( (o_i(ji,jj,jl) - zshift_date) > 0._wp ) THEN |
---|
368 | vinfor(20) = vinfor(20) + a_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp ! MY ice area |
---|
369 | vinfor(28) = vinfor(28) + v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp |
---|
370 | vinfor(52) = vinfor(52) + sm_i(ji,jj,jl)*v_i(ji,jj,jl)*aire(ji,jj) * 1.e-12_wp !FY ice salinity |
---|
371 | zamy = zamy + a_i(ji,jj,jl) |
---|
372 | ENDIF |
---|
373 | END DO ! jl |
---|
374 | IF ( at_i(ji,jj) > 0.15 .AND. zafy > zamy ) THEN |
---|
375 | vinfor(22) = vinfor(22) + aire(ji,jj) * 1.e-12_wp ! Seasonal ice extent |
---|
376 | ENDIF |
---|
377 | IF ( at_i(ji,jj) > 0.15 .AND. zafy <= zamy ) THEN |
---|
378 | vinfor(24) = vinfor(24) + aire(ji,jj) * 1.e-12_wp ! Perennial ice extent |
---|
379 | ENDIF |
---|
380 | ENDIF ! tms |
---|
381 | END DO ! jj |
---|
382 | END DO ! ji |
---|
383 | zindb = 1.0 - MAX( 0.0,SIGN( 1._wp , -vinfor(26) ) ) !=0 if no multiyear ice 1 if yes |
---|
384 | vinfor(50) = zindb * vinfor(50) / MAX( vinfor(26) , epsi06 ) |
---|
385 | zindb = 1.0 - MAX( 0._wp , SIGN( 1._wp , -vinfor(28) ) ) !=0 if no multiyear ice 1 if yes |
---|
386 | vinfor(52) = zindb * vinfor(52) / MAX( vinfor(28) , epsi06 ) |
---|
387 | |
---|
388 | ! Accumulation before averaging |
---|
389 | DO jv = 1, nvinfo |
---|
390 | vinfom(jv) = vinfom(jv) + vinfor(jv) |
---|
391 | END DO |
---|
392 | naveg = naveg + 1 |
---|
393 | |
---|
394 | ! oututs on file ice_evolu |
---|
395 | !MV IF( MOD( numit , ninfo ) == 0 ) THEN |
---|
396 | WRITE(numevo_ice,fmtw) ( titvar(jv), vinfom(jv)/naveg, jv = 1, nvinfo ) |
---|
397 | naveg = 0 |
---|
398 | DO jv = 1, nvinfo |
---|
399 | vinfom(jv) = 0._wp |
---|
400 | END DO |
---|
401 | !MV ENDIF |
---|
402 | ! |
---|
403 | END SUBROUTINE lim_dia |
---|
404 | |
---|
405 | |
---|
406 | SUBROUTINE lim_dia_init |
---|
407 | !!------------------------------------------------------------------- |
---|
408 | !! *** ROUTINE lim_dia_init *** |
---|
409 | !! |
---|
410 | !! ** Purpose : Preparation of the file ice_evolu for the output of |
---|
411 | !! the temporal evolution of key variables |
---|
412 | !! |
---|
413 | !! ** input : Namelist namicedia |
---|
414 | !!------------------------------------------------------------------- |
---|
415 | INTEGER :: jv ! dummy loop indice |
---|
416 | INTEGER :: ierr, ntot , ndeb , irecl ! local integers |
---|
417 | REAL(wp) :: zxx0, zxx1 ! local scalars |
---|
418 | CHARACTER(len=jpchinf) :: titinf |
---|
419 | CHARACTER(len=50) :: clname |
---|
420 | !! |
---|
421 | NAMELIST/namicedia/fmtinf, nfrinf, ninfo, ntmoy |
---|
422 | !!------------------------------------------------------------------- |
---|
423 | ! |
---|
424 | REWIND( numnam_ice ) ! read namicedia namelist |
---|
425 | READ ( numnam_ice, namicedia ) |
---|
426 | ! |
---|
427 | IF(lwp) THEN ! control print |
---|
428 | WRITE(numout,*) |
---|
429 | WRITE(numout,*) 'lim_dia_init : ice parameters for ice diagnostics ' |
---|
430 | WRITE(numout,*) '~~~~~~~~~~~~' |
---|
431 | WRITE(numout,*) ' format of the output values fmtinf = ', fmtinf |
---|
432 | WRITE(numout,*) ' number of variables written in one line nfrinf = ', nfrinf |
---|
433 | WRITE(numout,*) ' Instantaneous values of ice evolution or averaging ntmoy = ', ntmoy |
---|
434 | WRITE(numout,*) ' frequency of ouputs on file ice_evolu in case of averaging ninfo = ', ninfo |
---|
435 | ENDIF |
---|
436 | |
---|
437 | ALLOCATE( aire(jpi,jpj) , STAT=ierr ) ! masked grid cell area (interior domain only) |
---|
438 | IF( lk_mpp ) CALL mpp_sum( ierr ) |
---|
439 | IF( ierr /= 0 ) CALL ctl_stop( 'STOP', 'lim_dia_init_2 : unable to allocate arrays' ) |
---|
440 | aire(:,:) = area(:,:) * tms(:,:) * tmask_i(:,:) |
---|
441 | |
---|
442 | ! Titles of ice key variables : |
---|
443 | titvar(1) = 'NoIt' ! iteration number |
---|
444 | titvar(2) = 'T yr' ! time step in years |
---|
445 | nbvt = 2 ! number of time variables |
---|
446 | |
---|
447 | titvar(3) = 'AI_N' ! sea ice area in the northern Hemisp.(10^12 km2) |
---|
448 | titvar(4) = 'AI_S' ! sea ice area in the southern Hemisp.(10^12 km2) |
---|
449 | titvar(5) = 'EI_N' ! sea ice extent (15%) in the northern Hemisp.(10^12 km2) |
---|
450 | titvar(6) = 'EI_S' ! sea ice extent (15%) in the southern Hemisp.(10^12 km2) |
---|
451 | titvar(7) = 'VI_N' ! sea ice volume in the northern Hemisp.(10^3 km3) |
---|
452 | titvar(8) = 'VI_S' ! sea ice volume in the southern Hemisp.(10^3 km3) |
---|
453 | titvar(9) = 'VS_N' ! snow volume over sea ice in the northern Hemisp.(10^3 km3) |
---|
454 | titvar(10)= 'VS_S' ! snow volume over sea ice in the northern Hemisp.(10^3 km3) |
---|
455 | titvar(11)= 'VuIN' ! undeformed sea ice volume in the northern Hemisp.(10^3 km3) |
---|
456 | titvar(12)= 'VuIS' ! undeformed sea ice volume in the southern Hemisp.(10^3 km3) |
---|
457 | titvar(13)= 'VdIN' ! deformed sea ice volume in the northern Hemisp.(10^3 km3) |
---|
458 | titvar(14)= 'VdIS' ! deformed sea ice volume in the southern Hemisp.(10^3 km3) |
---|
459 | titvar(15)= 'OI_N' ! sea ice mean age in the northern Hemisp.(years) |
---|
460 | titvar(16)= 'OI_S' ! sea ice mean age in the southern Hemisp.(years) |
---|
461 | titvar(17)= 'AFYN' ! total FY ice area northern Hemisp.(10^12 km2) |
---|
462 | titvar(18)= 'AFYS' ! total FY ice area southern Hemisp.(10^12 km2) |
---|
463 | titvar(19)= 'AMYN' ! total MY ice area northern Hemisp.(10^12 km2) |
---|
464 | titvar(20)= 'AMYS' ! total MY ice area southern Hemisp.(10^12 km2) |
---|
465 | titvar(21)= 'EFYN' ! total FY ice extent northern Hemisp.(10^12 km2) (with more 50% FY ice) |
---|
466 | titvar(22)= 'EFYS' ! total FY ice extent southern Hemisp.(10^12 km2) (with more 50% FY ice) |
---|
467 | titvar(23)= 'EMYN' ! total MY ice extent northern Hemisp.(10^12 km2) (with more 50% MY ice) |
---|
468 | titvar(24)= 'EMYS' ! total MY ice extent southern Hemisp.(10^12 km2) (with more 50% MY ice) |
---|
469 | titvar(25)= 'VFYN' ! total undeformed FY ice volume northern Hemisp.(10^3 km3) |
---|
470 | titvar(26)= 'VFYS' ! total undeformed FY ice volume southern Hemisp.(10^3 km3) |
---|
471 | titvar(27)= 'VMYN' ! total undeformed MY ice volume northern Hemisp.(10^3 km3) |
---|
472 | titvar(28)= 'VMYS' ! total undeformed MY ice volume southern Hemisp.(10^3 km3) |
---|
473 | titvar(29)= 'IS_N' ! sea ice mean salinity in the northern hemisphere (ppt) |
---|
474 | titvar(30)= 'IS_S' ! sea ice mean salinity in the southern hemisphere (ppt) |
---|
475 | titvar(31)= 'IVeN' ! sea ice mean velocity in the northern hemisphere (m/s) |
---|
476 | titvar(32)= 'IVeS' ! sea ice mean velocity in the southern hemisphere (m/s) |
---|
477 | titvar(33)= 'DVDN' ! variation of sea ice volume due to dynamics in the northern hemisphere |
---|
478 | titvar(34)= 'DVDS' ! variation of sea ice volume due to dynamics in the southern hemisphere |
---|
479 | titvar(35)= 'DVTN' ! variation of sea ice volume due to thermo in the northern hemisphere |
---|
480 | titvar(36)= 'DVTS' ! variation of sea ice volume due to thermo in the southern hemisphere |
---|
481 | titvar(37)= 'TG1N' ! thermodynamic vertical growth rate in the northern hemisphere, cat 1 |
---|
482 | titvar(38)= 'TG1S' ! thermodynamic vertical growth rate in the souhtern hemisphere, cat 1 |
---|
483 | titvar(39)= 'TG2N' ! thermodynamic vertical growth rate in the northern hemisphere, cat 2 |
---|
484 | titvar(40)= 'TG2S' ! thermodynamic vertical growth rate in the souhtern hemisphere, cat 2 |
---|
485 | titvar(41)= 'TG3N' ! thermodynamic vertical growth rate in the northern hemisphere, cat 3 |
---|
486 | titvar(42)= 'TG3S' ! thermodynamic vertical growth rate in the souhtern hemisphere, cat 3 |
---|
487 | titvar(43)= 'TG4N' ! thermodynamic vertical growth rate in the northern hemisphere, cat 4 |
---|
488 | titvar(44)= 'TG4S' ! thermodynamic vertical growth rate in the souhtern hemisphere, cat 4 |
---|
489 | titvar(45)= 'TG5N' ! thermodynamic vertical growth rate in the northern hemisphere, cat 5 |
---|
490 | titvar(46)= 'TG5S' ! thermodynamic vertical growth rate in the souhtern hemisphere, cat 5 |
---|
491 | titvar(47)= 'LA_N' ! lateral accretion growth rate, northern hemisphere |
---|
492 | titvar(48)= 'LA_S' ! lateral accretion growth rate, southern hemisphere |
---|
493 | titvar(49)= 'SF_N' ! Salinity FY, NH |
---|
494 | titvar(50)= 'SF_S' ! Salinity FY, SH |
---|
495 | titvar(51)= 'SF_N' ! Salinity MY, NH |
---|
496 | titvar(52)= 'SF_S' ! Salinity MY, SH |
---|
497 | titvar(53)= 'Fs_N' ! Total salt flux NH |
---|
498 | titvar(54)= 'Fs_S' ! Total salt flux SH |
---|
499 | titvar(55)= 'FsbN' ! Salt - brine drainage flux NH |
---|
500 | titvar(56)= 'FsbS' ! Salt - brine drainage flux SH |
---|
501 | titvar(57)= 'FseN' ! Salt - Equivalent salt flux NH |
---|
502 | titvar(58)= 'FseS' ! Salt - Equivalent salt flux SH |
---|
503 | titvar(59)= 'SSTN' ! SST, NH |
---|
504 | titvar(60)= 'SSTS' ! SST, SH |
---|
505 | titvar(61)= 'SSSN' ! SSS, NH |
---|
506 | titvar(62)= 'SSSS' ! SSS, SH |
---|
507 | titvar(63)= 'TsuN' ! Tsu, NH |
---|
508 | titvar(64)= 'TsuS' ! Tsu, SH |
---|
509 | titvar(65)= 'TsnN' ! Tsn, NH |
---|
510 | titvar(66)= 'TsnS' ! Tsn, SH |
---|
511 | titvar(67)= 'ei_N' ! ei, NH |
---|
512 | titvar(68)= 'ei_S' ! ei, SH |
---|
513 | titvar(69)= 'vi1N' ! vi1, NH |
---|
514 | titvar(70)= 'vi1S' ! vi1, SH |
---|
515 | titvar(71)= 'vi2N' ! vi2, NH |
---|
516 | titvar(72)= 'vi2S' ! vi2, SH |
---|
517 | titvar(73)= 'vi3N' ! vi3, NH |
---|
518 | titvar(74)= 'vi3S' ! vi3, SH |
---|
519 | titvar(75)= 'vi4N' ! vi4, NH |
---|
520 | titvar(76)= 'vi4S' ! vi4, SH |
---|
521 | titvar(77)= 'vi5N' ! vi5, NH |
---|
522 | titvar(78)= 'vi5S' ! vi5, SH |
---|
523 | titvar(79)= 'vi6N' ! vi6, NH |
---|
524 | titvar(80)= 'vi6S' ! vi6, SH |
---|
525 | titvar(81)= 'fmaN' ! mass flux in the ocean, NH |
---|
526 | titvar(82)= 'fmaS' ! mass flux in the ocean, SH |
---|
527 | titvar(83)= 'AFSE' ! Fram Strait Area export |
---|
528 | titvar(84)= 'VFSE' ! Fram Strait Volume export |
---|
529 | nvinfo = 84 |
---|
530 | |
---|
531 | ! Definition et Ecriture de l'entete : nombre d'enregistrements |
---|
532 | ndeb = ( nstart - 1 ) / ninfo |
---|
533 | IF( nstart == 1 ) ndeb = -1 |
---|
534 | |
---|
535 | nferme = ( nstart - 1 + nitrun) / ninfo |
---|
536 | ntot = nferme - ndeb |
---|
537 | ndeb = ninfo * ( 1 + ndeb ) |
---|
538 | nferme = ninfo * nferme |
---|
539 | |
---|
540 | ! definition of formats |
---|
541 | WRITE( fmtw , '(A,I3,A2,I1,A)' ) '(', nfrinf, '(A', jpchsep, ','//fmtinf//'))' |
---|
542 | WRITE( fmtr , '(A,I3,A,I1,A)' ) '(', nfrinf, '(', jpchsep, 'X,'//fmtinf//'))' |
---|
543 | WRITE( fmtitr, '(A,I3,A,I1,A)' ) '(', nvinfo, 'A', jpchinf, ')' |
---|
544 | |
---|
545 | ! opening "ice_evolu" file |
---|
546 | IF( lk_mpp ) THEN ; WRITE(clname,FMT="('ice.evolu_',I4.4)") narea-1 |
---|
547 | ELSE ; clname = 'ice.evolu' |
---|
548 | END IF |
---|
549 | irecl = ( jpchinf + 1 ) * nvinfo |
---|
550 | CALL ctl_opn( numevo_ice, clname, 'UNKNOWN', 'FORMATTED', 'SEQUENTIAL', & |
---|
551 | & irecl, numout, lwp, narea ) |
---|
552 | |
---|
553 | !- ecriture de 2 lignes d''entete : |
---|
554 | WRITE(numevo_ice,1000) fmtr, fmtw, fmtitr, nvinfo, ntot, 0, nfrinf |
---|
555 | zxx0 = 0.001 * REAL(ninfo) |
---|
556 | zxx1 = 0.001 * REAL(ndeb) |
---|
557 | WRITE(numevo_ice,1111) REAL(jpchinf), 0., zxx1, zxx0, 0., 0., 0 |
---|
558 | |
---|
559 | !- ecriture de 2 lignes de titre : |
---|
560 | WRITE(numevo_ice,'(A,I8,A,I8,A,I5)') & |
---|
561 | 'Evolution chronologique - Experience '//cexper & |
---|
562 | //' de', ndeb, ' a', nferme, ' pas', ninfo |
---|
563 | WRITE(numevo_ice,fmtitr) ( titvar(jv), jv = 1, nvinfo ) |
---|
564 | |
---|
565 | !--preparation de "titvar" pour l''ecriture parmi les valeurs numeriques : |
---|
566 | DO jv = 2 , nvinfo |
---|
567 | titinf = titvar(jv)(:jpchinf) |
---|
568 | titvar(jv) = ' '//titinf |
---|
569 | END DO |
---|
570 | |
---|
571 | !--Initialisation of the arrays for the accumulation |
---|
572 | DO jv = 1, nvinfo |
---|
573 | vinfom(jv) = 0._wp |
---|
574 | END DO |
---|
575 | naveg = 0 |
---|
576 | |
---|
577 | 1000 FORMAT( 3(A20),4(1x,I6) ) |
---|
578 | 1111 FORMAT( 3(F7.1,1X,F7.3,1X),I3,A ) |
---|
579 | ! |
---|
580 | END SUBROUTINE lim_dia_init |
---|
581 | |
---|
582 | #else |
---|
583 | !!---------------------------------------------------------------------- |
---|
584 | !! Default option : NO LIM-3 sea-ice model |
---|
585 | !!---------------------------------------------------------------------- |
---|
586 | CONTAINS |
---|
587 | SUBROUTINE lim_dia ! Empty routine |
---|
588 | END SUBROUTINE lim_dia |
---|
589 | #endif |
---|
590 | |
---|
591 | !!====================================================================== |
---|
592 | END MODULE limdia |
---|