New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
limctl.F90 in branches/2015/dev_r5044_CNRS_LIM3CLEAN/NEMOGCM/NEMO/LIM_SRC_3 – NEMO

source: branches/2015/dev_r5044_CNRS_LIM3CLEAN/NEMOGCM/NEMO/LIM_SRC_3/limctl.F90 @ 5051

Last change on this file since 5051 was 5051, checked in by clem, 9 years ago

LIM3 initialization is now called at the same time as other sbc fields

File size: 23.4 KB
Line 
1MODULE limctl
2   !!======================================================================
3   !!                     ***  MODULE  limctl  ***
4   !!   LIM-3 : control and printing
5   !!======================================================================
6   !! History :  3.5  !  2015-01  (M. Vancoppenolle) Original code
7   !!----------------------------------------------------------------------
8#if defined key_lim3
9   !!----------------------------------------------------------------------
10   !!   'key_lim3'                                      LIM3 sea-ice model
11   !!----------------------------------------------------------------------
12   !!    lim_ctl   : control prints in case of crash
13   !!    lim_prt   : ice control print at a given grid point
14   !!----------------------------------------------------------------------
15   USE oce             ! ocean dynamics and tracers
16   USE dom_oce         ! ocean space and time domain
17   USE par_ice         ! sea-ice parameters
18   USE ice             ! LIM-3: ice variables
19   USE thd_ice         ! LIM-3: thermodynamical variables
20   USE dom_ice         ! LIM-3: ice domain
21   USE sbc_oce         ! Surface boundary condition: ocean fields
22   USE sbc_ice         ! Surface boundary condition: ice   fields
23
24   USE phycst          ! Define parameters for the routines
25
26   USE lib_mpp         ! MPP library
27   USE wrk_nemo        ! work arrays
28   USE timing          ! Timing
29   USE in_out_manager  ! I/O manager
30   USE prtctl          ! Print control
31   USE lib_fortran     !
32
33   IMPLICIT NONE
34   PRIVATE
35
36   PUBLIC   lim_ctl
37   PUBLIC   lim_prt
38
39   !! * Substitutions
40#  include "vectopt_loop_substitute.h90"
41   !!----------------------------------------------------------------------
42   !! NEMO/LIM3 4.0 , UCL - NEMO Consortium (2011)
43   !! $Id: limctl.F90 5043 2015-01-28 16:44:18Z clem $
44   !! Software governed by the CeCILL licence     (NEMOGCM/NEMO_CeCILL.txt)
45   !!----------------------------------------------------------------------
46
47CONTAINS
48
49   SUBROUTINE lim_ctl( kt )
50      !!-----------------------------------------------------------------------
51      !!                   ***  ROUTINE lim_ctl ***
52      !!                 
53      !! ** Purpose :   Alerts in case of model crash
54      !!-------------------------------------------------------------------
55      INTEGER, INTENT(in) ::   kt      ! ocean time step
56      INTEGER  ::   ji, jj, jk,  jl   ! dummy loop indices
57      INTEGER  ::   inb_altests       ! number of alert tests (max 20)
58      INTEGER  ::   ialert_id         ! number of the current alert
59      REAL(wp) ::   ztmelts           ! ice layer melting point
60      CHARACTER (len=30), DIMENSION(20)      ::   cl_alname   ! name of alert
61      INTEGER           , DIMENSION(20)      ::   inb_alp     ! number of alerts positive
62      !!-------------------------------------------------------------------
63
64      inb_altests = 10
65      inb_alp(:)  =  0
66
67      ! Alert if incompatible volume and concentration
68      ialert_id = 2 ! reference number of this alert
69      cl_alname(ialert_id) = ' Incompat vol and con         '    ! name of the alert
70
71      DO jl = 1, jpl
72         DO jj = 1, jpj
73            DO ji = 1, jpi
74               IF(  v_i(ji,jj,jl) /= 0._wp   .AND.   a_i(ji,jj,jl) == 0._wp   ) THEN
75                  !WRITE(numout,*) ' ALERTE 2 :   Incompatible volume and concentration '
76                  !WRITE(numout,*) ' at_i     ', at_i(ji,jj)
77                  !WRITE(numout,*) ' Point - category', ji, jj, jl
78                  !WRITE(numout,*) ' a_i *** a_i_b   ', a_i      (ji,jj,jl), a_i_b  (ji,jj,jl)
79                  !WRITE(numout,*) ' v_i *** v_i_b   ', v_i      (ji,jj,jl), v_i_b  (ji,jj,jl)
80                  !WRITE(numout,*) ' d_a_i_thd/trp   ', d_a_i_thd(ji,jj,jl), d_a_i_trp(ji,jj,jl)
81                  !WRITE(numout,*) ' d_v_i_thd/trp   ', d_v_i_thd(ji,jj,jl), d_v_i_trp(ji,jj,jl)
82                  inb_alp(ialert_id) = inb_alp(ialert_id) + 1
83               ENDIF
84            END DO
85         END DO
86      END DO
87
88      ! Alerte if very thick ice
89      ialert_id = 3 ! reference number of this alert
90      cl_alname(ialert_id) = ' Very thick ice               ' ! name of the alert
91      jl = jpl 
92      DO jj = 1, jpj
93         DO ji = 1, jpi
94            IF(   ht_i(ji,jj,jl)  >  50._wp   ) THEN
95               !CALL lim_prt( kt, ji, jj, 2, ' ALERTE 3 :   Very thick ice ' )
96               inb_alp(ialert_id) = inb_alp(ialert_id) + 1
97            ENDIF
98         END DO
99      END DO
100
101      ! Alert if very fast ice
102      ialert_id = 4 ! reference number of this alert
103      cl_alname(ialert_id) = ' Very fast ice               ' ! name of the alert
104      DO jj = 1, jpj
105         DO ji = 1, jpi
106            IF(   MAX( ABS( u_ice(ji,jj) ), ABS( v_ice(ji,jj) ) ) > 1.5  .AND.  &
107               &  at_i(ji,jj) > 0._wp   ) THEN
108               !CALL lim_prt( kt, ji, jj, 1, ' ALERTE 4 :   Very fast ice ' )
109               !WRITE(numout,*) ' ice strength             : ', strength(ji,jj)
110               !WRITE(numout,*) ' oceanic stress utau      : ', utau(ji,jj)
111               !WRITE(numout,*) ' oceanic stress vtau      : ', vtau(ji,jj)
112               !WRITE(numout,*) ' sea-ice stress utau_ice  : ', utau_ice(ji,jj)
113               !WRITE(numout,*) ' sea-ice stress vtau_ice  : ', vtau_ice(ji,jj)
114               !WRITE(numout,*) ' oceanic speed u          : ', u_oce(ji,jj)
115               !WRITE(numout,*) ' oceanic speed v          : ', v_oce(ji,jj)
116               !WRITE(numout,*) ' sst                      : ', sst_m(ji,jj)
117               !WRITE(numout,*) ' sss                      : ', sss_m(ji,jj)
118               !WRITE(numout,*)
119               inb_alp(ialert_id) = inb_alp(ialert_id) + 1
120            ENDIF
121         END DO
122      END DO
123
124      ! Alert if there is ice on continents
125      ialert_id = 6 ! reference number of this alert
126      cl_alname(ialert_id) = ' Ice on continents           ' ! name of the alert
127      DO jj = 1, jpj
128         DO ji = 1, jpi
129            IF(   tms(ji,jj) <= 0._wp   .AND.   at_i(ji,jj) > 0._wp   ) THEN 
130               !CALL lim_prt( kt, ji, jj, 1, ' ALERTE 6 :   Ice on continents ' )
131               !WRITE(numout,*) ' masks s, u, v        : ', tms(ji,jj), tmu(ji,jj), tmv(ji,jj)
132               !WRITE(numout,*) ' sst                  : ', sst_m(ji,jj)
133               !WRITE(numout,*) ' sss                  : ', sss_m(ji,jj)
134               !WRITE(numout,*) ' at_i(ji,jj)          : ', at_i(ji,jj)
135               !WRITE(numout,*) ' v_ice(ji,jj)         : ', v_ice(ji,jj)
136               !WRITE(numout,*) ' v_ice(ji,jj-1)       : ', v_ice(ji,jj-1)
137               !WRITE(numout,*) ' u_ice(ji-1,jj)       : ', u_ice(ji-1,jj)
138               !WRITE(numout,*) ' u_ice(ji,jj)         : ', v_ice(ji,jj)
139               !
140               inb_alp(ialert_id) = inb_alp(ialert_id) + 1
141            ENDIF
142         END DO
143      END DO
144
145!
146!     ! Alert if very fresh ice
147      ialert_id = 7 ! reference number of this alert
148      cl_alname(ialert_id) = ' Very fresh ice               ' ! name of the alert
149      DO jl = 1, jpl
150         DO jj = 1, jpj
151            DO ji = 1, jpi
152               IF( sm_i(ji,jj,jl) < 0.1 .AND. a_i(ji,jj,jl) > 0._wp ) THEN
153!                 CALL lim_prt(kt,ji,jj,1, ' ALERTE 7 :   Very fresh ice ' )
154!                 WRITE(numout,*) ' sst                  : ', sst_m(ji,jj)
155!                 WRITE(numout,*) ' sss                  : ', sss_m(ji,jj)
156!                 WRITE(numout,*)
157                  inb_alp(ialert_id) = inb_alp(ialert_id) + 1
158               ENDIF
159            END DO
160         END DO
161      END DO
162!
163
164!     ! Alert if too old ice
165      ialert_id = 9 ! reference number of this alert
166      cl_alname(ialert_id) = ' Very old   ice               ' ! name of the alert
167      DO jl = 1, jpl
168         DO jj = 1, jpj
169            DO ji = 1, jpi
170               IF ( ( ( ABS( o_i(ji,jj,jl) ) > rdt_ice ) .OR. &
171                      ( ABS( o_i(ji,jj,jl) ) < 0._wp) ) .AND. &
172                             ( a_i(ji,jj,jl) > 0._wp ) ) THEN
173                  !CALL lim_prt( kt, ji, jj, 1, ' ALERTE 9 :   Wrong ice age ')
174                  inb_alp(ialert_id) = inb_alp(ialert_id) + 1
175               ENDIF
176            END DO
177         END DO
178      END DO
179 
180      ! Alert on salt flux
181      ialert_id = 5 ! reference number of this alert
182      cl_alname(ialert_id) = ' High salt flux               ' ! name of the alert
183      DO jj = 1, jpj
184         DO ji = 1, jpi
185            IF( ABS( sfx (ji,jj) ) .GT. 1.0e-2 ) THEN  ! = 1 psu/day for 1m ocean depth
186               !CALL lim_prt( kt, ji, jj, 3, ' ALERTE 5 :   High salt flux ' )
187               !DO jl = 1, jpl
188                  !WRITE(numout,*) ' Category no: ', jl
189                  !WRITE(numout,*) ' a_i        : ', a_i      (ji,jj,jl) , ' a_i_b      : ', a_i_b  (ji,jj,jl)   
190                  !WRITE(numout,*) ' d_a_i_trp  : ', d_a_i_trp(ji,jj,jl) , ' d_a_i_thd  : ', d_a_i_thd(ji,jj,jl)
191                  !WRITE(numout,*) ' v_i        : ', v_i      (ji,jj,jl) , ' v_i_b      : ', v_i_b  (ji,jj,jl)   
192                  !WRITE(numout,*) ' d_v_i_trp  : ', d_v_i_trp(ji,jj,jl) , ' d_v_i_thd  : ', d_v_i_thd(ji,jj,jl)
193                  !WRITE(numout,*) ' '
194               !END DO
195               inb_alp(ialert_id) = inb_alp(ialert_id) + 1
196            ENDIF
197         END DO
198      END DO
199
200      ! Alert if qns very big
201      ialert_id = 8 ! reference number of this alert
202      cl_alname(ialert_id) = ' fnsolar very big             ' ! name of the alert
203      DO jj = 1, jpj
204         DO ji = 1, jpi
205            IF( ABS( qns(ji,jj) ) > 1500._wp .AND. at_i(ji,jj) > 0._wp ) THEN
206               !
207               !WRITE(numout,*) ' ALERTE 8 :   Very high non-solar heat flux'
208               !WRITE(numout,*) ' ji, jj    : ', ji, jj
209               !WRITE(numout,*) ' qns       : ', qns(ji,jj)
210               !WRITE(numout,*) ' sst       : ', sst_m(ji,jj)
211               !WRITE(numout,*) ' sss       : ', sss_m(ji,jj)
212               !
213               !CALL lim_prt( kt, ji, jj, 2, '   ')
214               inb_alp(ialert_id) = inb_alp(ialert_id) + 1
215               !
216            ENDIF
217         END DO
218      END DO
219      !+++++
220 
221      ! Alert if very warm ice
222      ialert_id = 10 ! reference number of this alert
223      cl_alname(ialert_id) = ' Very warm ice                ' ! name of the alert
224      inb_alp(ialert_id) = 0
225      DO jl = 1, jpl
226         DO jk = 1, nlay_i
227            DO jj = 1, jpj
228               DO ji = 1, jpi
229                  ztmelts    =  -tmut * s_i(ji,jj,jk,jl) + rtt
230                  IF( t_i(ji,jj,jk,jl) >= ztmelts  .AND.  v_i(ji,jj,jl) > 1.e-10   &
231                     &                             .AND.  a_i(ji,jj,jl) > 0._wp   ) THEN
232                     !WRITE(numout,*) ' ALERTE 10 :   Very warm ice'
233                     !WRITE(numout,*) ' ji, jj, jk, jl : ', ji, jj, jk, jl
234                     !WRITE(numout,*) ' t_i : ', t_i(ji,jj,jk,jl)
235                     !WRITE(numout,*) ' e_i : ', e_i(ji,jj,jk,jl)
236                     !WRITE(numout,*) ' s_i : ', s_i(ji,jj,jk,jl)
237                     !WRITE(numout,*) ' ztmelts : ', ztmelts
238                     inb_alp(ialert_id) = inb_alp(ialert_id) + 1
239                  ENDIF
240               END DO
241            END DO
242         END DO
243      END DO
244
245      ! sum of the alerts on all processors
246      IF( lk_mpp ) THEN
247         DO ialert_id = 1, inb_altests
248            CALL mpp_sum(inb_alp(ialert_id))
249         END DO
250      ENDIF
251
252      ! print alerts
253      IF( lwp ) THEN
254         ialert_id = 1                                 ! reference number of this alert
255         cl_alname(ialert_id) = ' NO alerte 1      '   ! name of the alert
256         WRITE(numout,*) ' time step ',kt
257         WRITE(numout,*) ' All alerts at the end of ice model '
258         DO ialert_id = 1, inb_altests
259            WRITE(numout,*) ialert_id, cl_alname(ialert_id)//' : ', inb_alp(ialert_id), ' times ! '
260         END DO
261      ENDIF
262     !
263   END SUBROUTINE lim_ctl
264 
265   
266   SUBROUTINE lim_prt( kt, ki, kj, kn, cd1 )
267      !!-----------------------------------------------------------------------
268      !!                   ***  ROUTINE lim_prt ***
269      !!                 
270      !! ** Purpose :   Writes global ice state on the (i,j) point
271      !!                in ocean.ouput
272      !!                3 possibilities exist
273      !!                n = 1/-1 -> simple ice state (plus Mechanical Check if -1)
274      !!                n = 2    -> exhaustive state
275      !!                n = 3    -> ice/ocean salt fluxes
276      !!
277      !! ** input   :   point coordinates (i,j)
278      !!                n : number of the option
279      !!-------------------------------------------------------------------
280      INTEGER         , INTENT(in) ::   kt            ! ocean time step
281      INTEGER         , INTENT(in) ::   ki, kj, kn    ! ocean gridpoint indices
282      CHARACTER(len=*), INTENT(in) ::   cd1           !
283      !!
284      INTEGER :: jl, ji, jj
285      !!-------------------------------------------------------------------
286
287      DO ji = mi0(ki), mi1(ki)
288         DO jj = mj0(kj), mj1(kj)
289
290            WRITE(numout,*) ' time step ',kt,' ',cd1             ! print title
291
292            !----------------
293            !  Simple state
294            !----------------
295           
296            IF ( kn == 1 .OR. kn == -1 ) THEN
297               WRITE(numout,*) ' lim_prt - Point : ',ji,jj
298               WRITE(numout,*) ' ~~~~~~~~~~~~~~ '
299               WRITE(numout,*) ' Simple state '
300               WRITE(numout,*) ' masks s,u,v   : ', tms(ji,jj), tmu(ji,jj), tmv(ji,jj)
301               WRITE(numout,*) ' lat - long    : ', gphit(ji,jj), glamt(ji,jj)
302               WRITE(numout,*) ' Time step     : ', numit
303               WRITE(numout,*) ' - Ice drift   '
304               WRITE(numout,*) '   ~~~~~~~~~~~ '
305               WRITE(numout,*) ' u_ice(i-1,j)  : ', u_ice(ji-1,jj)
306               WRITE(numout,*) ' u_ice(i  ,j)  : ', u_ice(ji,jj)
307               WRITE(numout,*) ' v_ice(i  ,j-1): ', v_ice(ji,jj-1)
308               WRITE(numout,*) ' v_ice(i  ,j)  : ', v_ice(ji,jj)
309               WRITE(numout,*) ' strength      : ', strength(ji,jj)
310               WRITE(numout,*)
311               WRITE(numout,*) ' - Cell values '
312               WRITE(numout,*) '   ~~~~~~~~~~~ '
313               WRITE(numout,*) ' cell area     : ', area(ji,jj)
314               WRITE(numout,*) ' at_i          : ', at_i(ji,jj)       
315               WRITE(numout,*) ' vt_i          : ', vt_i(ji,jj)       
316               WRITE(numout,*) ' vt_s          : ', vt_s(ji,jj)       
317               DO jl = 1, jpl
318                  WRITE(numout,*) ' - Category (', jl,')'
319                  WRITE(numout,*) ' a_i           : ', a_i(ji,jj,jl)
320                  WRITE(numout,*) ' ht_i          : ', ht_i(ji,jj,jl)
321                  WRITE(numout,*) ' ht_s          : ', ht_s(ji,jj,jl)
322                  WRITE(numout,*) ' v_i           : ', v_i(ji,jj,jl)
323                  WRITE(numout,*) ' v_s           : ', v_s(ji,jj,jl)
324                  WRITE(numout,*) ' e_s           : ', e_s(ji,jj,1,jl)/1.0e9
325                  WRITE(numout,*) ' e_i           : ', e_i(ji,jj,1:nlay_i,jl)/1.0e9
326                  WRITE(numout,*) ' t_su          : ', t_su(ji,jj,jl)
327                  WRITE(numout,*) ' t_snow        : ', t_s(ji,jj,1,jl)
328                  WRITE(numout,*) ' t_i           : ', t_i(ji,jj,1:nlay_i,jl)
329                  WRITE(numout,*) ' sm_i          : ', sm_i(ji,jj,jl)
330                  WRITE(numout,*) ' smv_i         : ', smv_i(ji,jj,jl)
331                  WRITE(numout,*)
332               END DO
333            ENDIF
334            IF( kn == -1 ) THEN
335               WRITE(numout,*) ' Mechanical Check ************** '
336               WRITE(numout,*) ' Check what means ice divergence '
337               WRITE(numout,*) ' Total ice concentration ', at_i (ji,jj)
338               WRITE(numout,*) ' Total lead fraction     ', ato_i(ji,jj)
339               WRITE(numout,*) ' Sum of both             ', ato_i(ji,jj) + at_i(ji,jj)
340               WRITE(numout,*) ' Sum of both minus 1     ', ato_i(ji,jj) + at_i(ji,jj) - 1.00
341            ENDIF
342           
343
344            !--------------------
345            !  Exhaustive state
346            !--------------------
347           
348            IF ( kn .EQ. 2 ) THEN
349               WRITE(numout,*) ' lim_prt - Point : ',ji,jj
350               WRITE(numout,*) ' ~~~~~~~~~~~~~~ '
351               WRITE(numout,*) ' Exhaustive state '
352               WRITE(numout,*) ' lat - long ', gphit(ji,jj), glamt(ji,jj)
353               WRITE(numout,*) ' Time step ', numit
354               WRITE(numout,*) 
355               WRITE(numout,*) ' - Cell values '
356               WRITE(numout,*) '   ~~~~~~~~~~~ '
357               WRITE(numout,*) ' cell area     : ', area(ji,jj)
358               WRITE(numout,*) ' at_i          : ', at_i(ji,jj)       
359               WRITE(numout,*) ' vt_i          : ', vt_i(ji,jj)       
360               WRITE(numout,*) ' vt_s          : ', vt_s(ji,jj)       
361               WRITE(numout,*) ' u_ice(i-1,j)  : ', u_ice(ji-1,jj)
362               WRITE(numout,*) ' u_ice(i  ,j)  : ', u_ice(ji,jj)
363               WRITE(numout,*) ' v_ice(i  ,j-1): ', v_ice(ji,jj-1)
364               WRITE(numout,*) ' v_ice(i  ,j)  : ', v_ice(ji,jj)
365               WRITE(numout,*) ' strength      : ', strength(ji,jj)
366               WRITE(numout,*) ' d_u_ice_dyn   : ', d_u_ice_dyn(ji,jj), ' d_v_ice_dyn   : ', d_v_ice_dyn(ji,jj)
367               WRITE(numout,*) ' u_ice_b       : ', u_ice_b(ji,jj)    , ' v_ice_b       : ', v_ice_b(ji,jj) 
368               WRITE(numout,*)
369               
370               DO jl = 1, jpl
371                  WRITE(numout,*) ' - Category (',jl,')'
372                  WRITE(numout,*) '   ~~~~~~~~         ' 
373                  WRITE(numout,*) ' ht_i       : ', ht_i(ji,jj,jl)             , ' ht_s       : ', ht_s(ji,jj,jl)
374                  WRITE(numout,*) ' t_i        : ', t_i(ji,jj,1:nlay_i,jl)
375                  WRITE(numout,*) ' t_su       : ', t_su(ji,jj,jl)             , ' t_s        : ', t_s(ji,jj,1,jl)
376                  WRITE(numout,*) ' sm_i       : ', sm_i(ji,jj,jl)             , ' o_i        : ', o_i(ji,jj,jl)
377                  WRITE(numout,*) ' a_i        : ', a_i(ji,jj,jl)              , ' a_i_b      : ', a_i_b(ji,jj,jl)   
378                  WRITE(numout,*) ' d_a_i_trp  : ', d_a_i_trp(ji,jj,jl)        , ' d_a_i_thd  : ', d_a_i_thd(ji,jj,jl) 
379                  WRITE(numout,*) ' v_i        : ', v_i(ji,jj,jl)              , ' v_i_b      : ', v_i_b(ji,jj,jl)   
380                  WRITE(numout,*) ' d_v_i_trp  : ', d_v_i_trp(ji,jj,jl)        , ' d_v_i_thd  : ', d_v_i_thd(ji,jj,jl) 
381                  WRITE(numout,*) ' v_s        : ', v_s(ji,jj,jl)              , ' v_s_b      : ', v_s_b(ji,jj,jl) 
382                  WRITE(numout,*) ' d_v_s_trp  : ', d_v_s_trp(ji,jj,jl)        , ' d_v_s_thd  : ', d_v_s_thd(ji,jj,jl)
383                  WRITE(numout,*) ' e_i1       : ', e_i(ji,jj,1,jl)/1.0e9      , ' ei1        : ', e_i_b(ji,jj,1,jl)/1.0e9 
384                  WRITE(numout,*) ' de_i1_trp  : ', d_e_i_trp(ji,jj,1,jl)/1.0e9, ' de_i1_thd  : ', d_e_i_thd(ji,jj,1,jl)/1.0e9
385                  WRITE(numout,*) ' e_i2       : ', e_i(ji,jj,2,jl)/1.0e9      , ' ei2_b      : ', e_i_b(ji,jj,2,jl)/1.0e9 
386                  WRITE(numout,*) ' de_i2_trp  : ', d_e_i_trp(ji,jj,2,jl)/1.0e9, ' de_i2_thd  : ', d_e_i_thd(ji,jj,2,jl)/1.0e9
387                  WRITE(numout,*) ' e_snow     : ', e_s(ji,jj,1,jl)            , ' e_snow_b   : ', e_s_b(ji,jj,1,jl) 
388                  WRITE(numout,*) ' d_e_s_trp  : ', d_e_s_trp(ji,jj,1,jl)      , ' d_e_s_thd  : ', d_e_s_thd(ji,jj,1,jl)
389                  WRITE(numout,*) ' smv_i      : ', smv_i(ji,jj,jl)            , ' smv_i_b    : ', smv_i_b(ji,jj,jl)   
390                  WRITE(numout,*) ' d_smv_i_trp: ', d_smv_i_trp(ji,jj,jl)      , ' d_smv_i_thd: ', d_smv_i_thd(ji,jj,jl) 
391                  WRITE(numout,*) ' oa_i       : ', oa_i(ji,jj,jl)             , ' oa_i_b     : ', oa_i_b(ji,jj,jl)
392                  WRITE(numout,*) ' d_oa_i_trp : ', d_oa_i_trp(ji,jj,jl)       , ' d_oa_i_thd : ', d_oa_i_thd(ji,jj,jl)
393               END DO !jl
394               
395               WRITE(numout,*)
396               WRITE(numout,*) ' - Heat / FW fluxes '
397               WRITE(numout,*) '   ~~~~~~~~~~~~~~~~ '
398               WRITE(numout,*) ' - Heat fluxes in and out the ice ***'
399               WRITE(numout,*) ' qsr_ini       : ', pfrld(ji,jj) * qsr(ji,jj) + SUM( a_i_b(ji,jj,:) * qsr_ice(ji,jj,:) )
400               WRITE(numout,*) ' qns_ini       : ', pfrld(ji,jj) * qns(ji,jj) + SUM( a_i_b(ji,jj,:) * qns_ice(ji,jj,:) )
401               WRITE(numout,*)
402               WRITE(numout,*) 
403               WRITE(numout,*) ' sst        : ', sst_m(ji,jj) 
404               WRITE(numout,*) ' sss        : ', sss_m(ji,jj) 
405               WRITE(numout,*) 
406               WRITE(numout,*) ' - Stresses '
407               WRITE(numout,*) '   ~~~~~~~~ '
408               WRITE(numout,*) ' utau_ice   : ', utau_ice(ji,jj) 
409               WRITE(numout,*) ' vtau_ice   : ', vtau_ice(ji,jj)
410               WRITE(numout,*) ' utau       : ', utau    (ji,jj) 
411               WRITE(numout,*) ' vtau       : ', vtau    (ji,jj)
412               WRITE(numout,*) ' oc. vel. u : ', u_oce   (ji,jj)
413               WRITE(numout,*) ' oc. vel. v : ', v_oce   (ji,jj)
414            ENDIF
415           
416            !---------------------
417            ! Salt / heat fluxes
418            !---------------------
419           
420            IF ( kn .EQ. 3 ) THEN
421               WRITE(numout,*) ' lim_prt - Point : ',ji,jj
422               WRITE(numout,*) ' ~~~~~~~~~~~~~~ '
423               WRITE(numout,*) ' - Salt / Heat Fluxes '
424               WRITE(numout,*) '   ~~~~~~~~~~~~~~~~ '
425               WRITE(numout,*) ' lat - long ', gphit(ji,jj), glamt(ji,jj)
426               WRITE(numout,*) ' Time step ', numit
427               WRITE(numout,*)
428               WRITE(numout,*) ' - Heat fluxes at bottom interface ***'
429               WRITE(numout,*) ' qsr       : ', qsr(ji,jj)
430               WRITE(numout,*) ' qns       : ', qns(ji,jj)
431               WRITE(numout,*)
432               WRITE(numout,*) ' hfx_mass     : ', hfx_thd(ji,jj) + hfx_dyn(ji,jj) + hfx_snw(ji,jj) + hfx_res(ji,jj)
433               WRITE(numout,*) ' hfx_in       : ', hfx_in(ji,jj)
434               WRITE(numout,*) ' hfx_out      : ', hfx_out(ji,jj)
435               WRITE(numout,*) ' dhc          : ', diag_heat_dhc(ji,jj)             
436               WRITE(numout,*)
437               WRITE(numout,*) ' hfx_dyn      : ', hfx_dyn(ji,jj)
438               WRITE(numout,*) ' hfx_thd      : ', hfx_thd(ji,jj)
439               WRITE(numout,*) ' hfx_res      : ', hfx_res(ji,jj)
440               WRITE(numout,*) ' fhtur        : ', fhtur(ji,jj) 
441               WRITE(numout,*) ' qlead        : ', qlead(ji,jj) * r1_rdtice
442               WRITE(numout,*)
443               WRITE(numout,*) ' - Salt fluxes at bottom interface ***'
444               WRITE(numout,*) ' emp       : ', emp    (ji,jj)
445               WRITE(numout,*) ' sfx       : ', sfx    (ji,jj)
446               WRITE(numout,*) ' sfx_res   : ', sfx_res(ji,jj)
447               WRITE(numout,*) ' sfx_bri   : ', sfx_bri(ji,jj)
448               WRITE(numout,*) ' sfx_dyn   : ', sfx_dyn(ji,jj)
449               WRITE(numout,*)
450               WRITE(numout,*) ' - Momentum fluxes '
451               WRITE(numout,*) ' utau      : ', utau(ji,jj) 
452               WRITE(numout,*) ' vtau      : ', vtau(ji,jj)
453            ENDIF
454            WRITE(numout,*) ' '
455            !
456         END DO
457      END DO
458      !
459   END SUBROUTINE lim_prt
460
461#else
462   !!--------------------------------------------------------------------------
463   !!   Default option         Empty Module               No LIM3 sea-ice model
464   !!--------------------------------------------------------------------------
465CONTAINS
466   SUBROUTINE lim_ctl     ! Empty routine
467   END SUBROUTINE lim_ctl
468   SUBROUTINE lim_prt     ! Empty routine
469   END SUBROUTINE lim_prt
470#endif
471   !!======================================================================
472END MODULE limctl
Note: See TracBrowser for help on using the repository browser.