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.
tranpc.F90 in trunk/NEMOGCM/NEMO/OPA_SRC/TRA – NEMO

source: trunk/NEMOGCM/NEMO/OPA_SRC/TRA/tranpc.F90 @ 2528

Last change on this file since 2528 was 2528, checked in by rblod, 13 years ago

Update NEMOGCM from branch nemo_v3_3_beta

  • Property svn:keywords set to Id
File size: 9.6 KB
RevLine 
[3]1MODULE tranpc
2   !!==============================================================================
3   !!                       ***  MODULE  tranpc  ***
4   !! Ocean active tracers:  non penetrative convection scheme
5   !!==============================================================================
[1537]6   !! History :  1.0  ! 1990-09  (G. Madec)  Original code
7   !!                 ! 1996-01  (G. Madec)  statement function for e3
8   !!   NEMO     1.0  ! 2002-06  (G. Madec)  free form F90
9   !!            3.0  ! 2008-06  (G. Madec)  applied on ta, sa and called before tranxt in step.F90
[2528]10   !!            3.3  ! 2010-05  (C. Ethe, G. Madec)  merge TRC-TRA
[503]11   !!----------------------------------------------------------------------
[3]12
13   !!----------------------------------------------------------------------
[1537]14   !!   tra_npc : apply the non penetrative convection scheme
[3]15   !!----------------------------------------------------------------------
16   USE oce             ! ocean dynamics and active tracers
17   USE dom_oce         ! ocean space and time domain
[1537]18   USE zdf_oce         ! ocean vertical physics
[2528]19   USE trdmod_oce      ! ocean active tracer trends
20   USE trdtra      ! ocean active tracer trends
[3]21   USE eosbn2          ! equation of state (eos routine)
22   USE lbclnk          ! lateral boundary conditions (or mpp link)
[216]23   USE in_out_manager  ! I/O manager
[3]24
25   IMPLICIT NONE
26   PRIVATE
27
[503]28   PUBLIC   tra_npc    ! routine called by step.F90
[3]29
30   !! * Substitutions
31#  include "domzgr_substitute.h90"
32   !!----------------------------------------------------------------------
[2528]33   !! NEMO/OPA 3.3 , NEMO Consortium (2010)
[1146]34   !! $Id$
[2528]35   !! Software governed by the CeCILL licence     (NEMOGCM/NEMO_CeCILL.txt)
[3]36   !!----------------------------------------------------------------------
37CONTAINS
38
39   SUBROUTINE tra_npc( kt )
40      !!----------------------------------------------------------------------
41      !!                  ***  ROUTINE tranpc  ***
42      !!
43      !! ** Purpose :   Non penetrative convective adjustment scheme. solve
[1111]44      !!      the static instability of the water column on after fields
[3]45      !!      while conserving heat and salt contents.
46      !!
47      !! ** Method  :   The algorithm used converges in a maximium of jpk
48      !!      iterations. instabilities are treated when the vertical density
49      !!      gradient is less than 1.e-5.
[503]50      !!      l_trdtra=T: the trend associated with this algorithm is saved.
[3]51      !!
[1111]52      !! ** Action  : - (ta,sa) after the application od the npc scheme
[3]53      !!              - save the associated trends (ttrd,strd) ('key_trdtra')
54      !!
[503]55      !! References : Madec, et al., 1991, JPO, 21, 9, 1349-1371.
56      !!----------------------------------------------------------------------
57      INTEGER, INTENT(in) ::   kt   ! ocean time-step index
[3]58      !!
[503]59      INTEGER  ::   ji, jj, jk   ! dummy loop indices
60      INTEGER  ::   inpcc        ! number of statically instable water column
61      INTEGER  ::   inpci        ! number of iteration for npc scheme
62      INTEGER  ::   jiter, jkdown, jkp        ! ???
63      INTEGER  ::   ikbot, ik, ikup, ikdown   ! ???
64      REAL(wp) ::   ze3tot, zta, zsa, zraua, ze3dwn
65      REAL(wp), DIMENSION(jpi,jpk)     ::   zwx, zwy, zwz   ! 2D arrays
66      REAL(wp), DIMENSION(jpi,jpj,jpk) ::   zrhop           ! 3D arrays
[2528]67      REAL(wp), DIMENSION(:,:,:), ALLOCATABLE ::  ztrdt, ztrds
[3]68      !!----------------------------------------------------------------------
[216]69
[1537]70      IF( MOD( kt, nn_npc ) == 0 ) THEN
[3]71
72         inpcc = 0
73         inpci = 0
74
[2528]75         CALL eos( tsa, rhd, zrhop )         ! Potential density
[3]76
[2528]77         IF( l_trdtra )   THEN                    !* Save ta and sa trends
78            ALLOCATE( ztrdt(jpi,jpj,jpk) )  ;    ztrdt(:,:,:) = tsa(:,:,:,jp_tem) 
79            ALLOCATE( ztrds(jpi,jpj,jpk) )  ;    ztrds(:,:,:) = tsa(:,:,:,jp_sal)
[216]80         ENDIF
81
[3]82         !                                                ! ===============
83         DO jj = 1, jpj                                   !  Vertical slab
84            !                                             ! ===============
[503]85            !  Static instability pointer
86            ! ----------------------------
[3]87            DO jk = 1, jpkm1
88               DO ji = 1, jpi
89                  zwx(ji,jk) = ( zrhop(ji,jj,jk) - zrhop(ji,jj,jk+1) ) * tmask(ji,jj,jk+1)
90               END DO
91            END DO
92
93            ! 1.1 do not consider the boundary points
94
95            ! even if east-west cyclic b. c. do not considere ji=1 or jpi
96            DO jk = 1, jpkm1
97               zwx( 1 ,jk) = 0.e0
98               zwx(jpi,jk) = 0.e0
99            END DO
100            ! even if south-symmetric b. c. used, do not considere jj=1
[503]101            IF( jj == 1 )   zwx(:,:) = 0.e0
[3]102
103            DO jk = 1, jpkm1
104               DO ji = 1, jpi
105                  zwx(ji,jk) = 1.
[503]106                  IF( zwx(ji,jk) < 1.e-5 ) zwx(ji,jk) = 0.e0
[3]107               END DO
108            END DO
109
[503]110            zwy(:,1) = 0.e0
[3]111            DO ji = 1, jpi
112               DO jk = 1, jpkm1
113                  zwy(ji,1) = zwy(ji,1) + zwx(ji,jk)
114               END DO
115            END DO
116
[503]117            zwz(1,1) = 0.e0
[3]118            DO ji = 1, jpi
119               zwz(1,1) = zwz(1,1) + zwy(ji,1)
120            END DO
121
122            inpcc = inpcc + NINT( zwz(1,1) )
123
124
125            ! 2. Vertical mixing for each instable portion of the density profil
126            ! ------------------------------------------------------------------
127
[503]128            IF( zwz(1,1) /= 0.e0 ) THEN         ! -->> the density profil is statically instable :
[3]129               DO ji = 1, jpi
[503]130                  IF( zwy(ji,1) /= 0.e0 ) THEN
131                     !
[2528]132                     ikbot = mbkt(ji,jj)        ! ikbot: ocean bottom T-level
[503]133                     !
134                     DO jiter = 1, jpk          ! vertical iteration
135                        !
[3]136                        ! search of ikup : the first static instability from the sea surface
[503]137                        !
[3]138                        ik = 0
139220                     CONTINUE
140                        ik = ik + 1
[2528]141                        IF( ik >= ikbot ) GO TO 200
[3]142                        zwx(ji,ik) = zrhop(ji,jj,ik) - zrhop(ji,jj,ik+1)
[503]143                        IF( zwx(ji,ik) <= 0.e0 ) GO TO 220
[3]144                        ikup = ik
145                        ! the density profil is instable below ikup
146                        ! ikdown : bottom of the instable portion of the density profil
147                        ! search of ikdown and vertical mixing from ikup to ikdown
[503]148                        !
[3]149                        ze3tot= fse3t(ji,jj,ikup)
[2528]150                        zta   = tsa  (ji,jj,ikup,jp_tem)
151                        zsa   = tsa  (ji,jj,ikup,jp_sal)
[3]152                        zraua = zrhop(ji,jj,ikup)
[503]153                        !
[3]154                        DO jkdown = ikup+1, ikbot-1
155                           IF( zraua <= zrhop(ji,jj,jkdown) ) THEN
156                              ikdown = jkdown
157                              GO TO 240
158                           ENDIF
159                           ze3dwn =  fse3t(ji,jj,jkdown)
160                           ze3tot =  ze3tot + ze3dwn
[2528]161                           zta   = ( zta*(ze3tot-ze3dwn) + tsa(ji,jj,jkdown,jp_tem)*ze3dwn )/ze3tot
162                           zsa   = ( zsa*(ze3tot-ze3dwn) + tsa(ji,jj,jkdown,jp_sal)*ze3dwn )/ze3tot
[3]163                           zraua = ( zraua*(ze3tot-ze3dwn) + zrhop(ji,jj,jkdown)*ze3dwn )/ze3tot
164                           inpci = inpci+1
165                        END DO
166                        ikdown = ikbot-1
167240                     CONTINUE
[503]168                        !
[3]169                        DO jkp = ikup, ikdown-1
[2528]170                           tsa  (ji,jj,jkp,jp_tem) = zta
171                           tsa  (ji,jj,jkp,jp_sal) = zsa
172                           zrhop(ji,jj,jkp       ) = zraua
[3]173                        END DO
174                        IF (ikdown == ikbot-1 .AND. zraua >= zrhop(ji,jj,ikdown) ) THEN
[2528]175                           tsa  (ji,jj,jkp,jp_tem) = zta
176                           tsa  (ji,jj,jkp,jp_sal) = zsa
177                           zrhop(ji,jj,ikdown    ) = zraua
[3]178                        ENDIF
179                     END DO
180                  ENDIF
181200               CONTINUE
182               END DO
183               ! <<-- no more static instability on slab jj
184            ENDIF
185            !                                             ! ===============
186         END DO                                           !   End of slab
187         !                                                ! ===============
[503]188         !
189         IF( l_trdtra )   THEN         ! save the Non penetrative mixing trends for diagnostic
[2528]190            ztrdt(:,:,:) = tsa(:,:,:,jp_tem) - ztrdt(:,:,:)
191            ztrds(:,:,:) = tsa(:,:,:,jp_sal) - ztrds(:,:,:)
192            CALL trd_tra( kt, 'TRA', jp_tem, jptra_trd_npc, ztrdt )
193            CALL trd_tra( kt, 'TRA', jp_sal, jptra_trd_npc, ztrds )
194            DEALLOCATE( ztrdt )      ;     DEALLOCATE( ztrds ) 
[216]195         ENDIF
[3]196     
[1111]197         ! Lateral boundary conditions on ( ta, sa )   ( Unchanged sign)
[3]198         ! ------------------------------============
[2528]199         CALL lbc_lnk( tsa(:,:,:,jp_tem), 'T', 1. )
200         CALL lbc_lnk( tsa(:,:,:,jp_sal), 'T', 1. )
[3]201     
202
203         !  2. non penetrative convective scheme statistics
204         !  -----------------------------------------------
[1537]205         IF( nn_npcp /= 0 .AND. MOD( kt, nn_npcp ) == 0 ) THEN
[3]206            IF(lwp) WRITE(numout,*)' kt=',kt, ' number of statically instable',   &
[503]207               &                   ' water column : ',inpcc, ' number of iteration : ',inpci
[3]208         ENDIF
[503]209         !
[3]210      ENDIF
[503]211      !
[3]212   END SUBROUTINE tra_npc
213
214   !!======================================================================
215END MODULE tranpc
Note: See TracBrowser for help on using the repository browser.