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.
Changeset 4921 for branches/2014/dev_r4650_UKMO13_CICE_changes_take2/NEMOGCM/NEMO/OPA_SRC/DIA/diawri.F90 – NEMO

Ignore:
Timestamp:
2014-11-28T14:59:01+01:00 (9 years ago)
Author:
timgraham
Message:

merged with revision 4879 of trunk

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/2014/dev_r4650_UKMO13_CICE_changes_take2/NEMOGCM/NEMO/OPA_SRC/DIA/diawri.F90

    r4570 r4921  
    4545   USE diadimg         ! dimg direct access file format output 
    4646   USE diaar5, ONLY :   lk_diaar5 
    47    USE dynadv, ONLY :   ln_dynadv_vec 
    4847   USE iom 
    4948   USE ioipsl 
     
    131130      REAL(wp)                     ::   zztmp, zztmpx, zztmpy   !  
    132131      !! 
    133       REAL(wp), POINTER, DIMENSION(:,:)   :: z2d       ! 2D workspace 
     132      REAL(wp), POINTER, DIMENSION(:,:)   :: z2d      ! 2D workspace 
     133      REAL(wp), POINTER, DIMENSION(:,:)   :: z2ds     ! 2D workspace 
    134134      REAL(wp), POINTER, DIMENSION(:,:,:) :: z3d      ! 3D workspace 
    135135      !!---------------------------------------------------------------------- 
     
    137137      IF( nn_timing == 1 )   CALL timing_start('dia_wri') 
    138138      !  
    139       CALL wrk_alloc( jpi , jpj      , z2d ) 
     139      CALL wrk_alloc( jpi , jpj      , z2d , z2ds ) 
    140140      CALL wrk_alloc( jpi , jpj, jpk , z3d ) 
    141141      ! 
     
    193193      CALL iom_put( "sstgrad" ,  z2d               )    ! module of sst gradient 
    194194 
     195      ! clem: heat and salt content 
     196      z2d(:,:)  = 0._wp  
     197      z2ds(:,:) = 0._wp  
     198      DO jk = 1, jpkm1 
     199         DO jj = 2, jpjm1 
     200            DO ji = fs_2, fs_jpim1   ! vector opt. 
     201               z2d(ji,jj) = z2d(ji,jj) + rau0 * rcp * fse3t(ji,jj,jk) * tsn(ji,jj,jk,jp_tem) * tmask(ji,jj,jk) 
     202               z2ds(ji,jj) = z2ds(ji,jj) + rau0 * fse3t(ji,jj,jk) * tsn(ji,jj,jk,jp_sal) * tmask(ji,jj,jk) 
     203            END DO 
     204         END DO 
     205      END DO 
     206      CALL lbc_lnk( z2d, 'T', 1. ) 
     207      CALL lbc_lnk( z2ds, 'T', 1. ) 
     208      CALL iom_put( "heatc", z2d )    ! vertically integrated heat content (J/m2) 
     209      CALL iom_put( "saltc", z2ds )   ! vertically integrated salt content (PSU*kg/m2) 
     210   
     211      ! 
     212      rke(:,:,jk) = 0._wp                               !      kinetic energy  
     213      DO jk = 1, jpkm1 
     214         DO jj = 2, jpjm1 
     215            DO ji = fs_2, fs_jpim1   ! vector opt. 
     216               zztmp   = 1._wp / ( e1e2t(ji,jj) * fse3t(ji,jj,jk) ) 
     217               zztmpx  = 0.5 * (  un(ji-1,jj,jk) * un(ji-1,jj,jk) * e2u(ji-1,jj) * fse3u(ji-1,jj,jk)    & 
     218                  &             + un(ji  ,jj,jk) * un(ji  ,jj,jk) * e2u(ji  ,jj) * fse3u(ji  ,jj,jk) )  & 
     219                  &          *  zztmp  
     220               ! 
     221               zztmpy  = 0.5 * (  vn(ji,jj-1,jk) * vn(ji,jj-1,jk) * e1v(ji,jj-1) * fse3v(ji,jj-1,jk)    & 
     222                  &             + vn(ji,jj  ,jk) * vn(ji,jj  ,jk) * e1v(ji,jj  ) * fse3v(ji,jj  ,jk) )  & 
     223                  &          *  zztmp  
     224               ! 
     225               rke(ji,jj,jk) = 0.5_wp * ( zztmpx + zztmpy ) 
     226               ! 
     227            ENDDO 
     228         ENDDO 
     229      ENDDO 
     230      CALL lbc_lnk( rke, 'T', 1. ) 
     231      CALL iom_put( "eken", rke )            
     232 
    195233      IF( lk_diaar5 ) THEN 
    196234         z3d(:,:,jpk) = 0.e0 
    197235         DO jk = 1, jpkm1 
    198             z3d(:,:,jk) = rau0 * un(:,:,jk) * e2u(:,:) * fse3u(:,:,jk) 
     236            z3d(:,:,jk) = rau0 * un(:,:,jk) * e2u(:,:) * fse3u(:,:,jk) * umask(:,:,jk) 
    199237         END DO 
    200238         CALL iom_put( "u_masstr", z3d )                  ! mass transport in i-direction 
     239 
    201240         zztmp = 0.5 * rcp 
    202241         z2d(:,:) = 0.e0  
     242         z2ds(:,:) = 0.e0  
    203243         DO jk = 1, jpkm1 
    204244            DO jj = 2, jpjm1 
    205245               DO ji = fs_2, fs_jpim1   ! vector opt. 
    206246                  z2d(ji,jj) = z2d(ji,jj) + z3d(ji,jj,jk) * zztmp * ( tsn(ji,jj,jk,jp_tem) + tsn(ji+1,jj,jk,jp_tem) ) 
     247                  z2ds(ji,jj) = z2ds(ji,jj) + z3d(ji,jj,jk) * 0.5_wp * ( tsn(ji,jj,jk,jp_sal) + tsn(ji+1,jj,jk,jp_sal) ) 
    207248               END DO 
    208249            END DO 
    209250         END DO 
    210251         CALL lbc_lnk( z2d, 'U', -1. ) 
     252         CALL lbc_lnk( z2ds, 'U', -1. ) 
    211253         CALL iom_put( "u_heattr", z2d )                  ! heat transport in i-direction 
     254         CALL iom_put( "u_salttr", z2ds )                 ! salt transport in i-direction 
     255 
     256         z3d(:,:,jpk) = 0.e0 
    212257         DO jk = 1, jpkm1 
    213             z3d(:,:,jk) = rau0 * vn(:,:,jk) * e1v(:,:) * fse3v(:,:,jk) 
     258            z3d(:,:,jk) = rau0 * vn(:,:,jk) * e1v(:,:) * fse3v(:,:,jk) * vmask(:,:,jk) 
    214259         END DO 
    215260         CALL iom_put( "v_masstr", z3d )                  ! mass transport in j-direction 
     261 
    216262         z2d(:,:) = 0.e0  
     263         z2ds(:,:) = 0.e0  
    217264         DO jk = 1, jpkm1 
    218265            DO jj = 2, jpjm1 
    219266               DO ji = fs_2, fs_jpim1   ! vector opt. 
    220267                  z2d(ji,jj) = z2d(ji,jj) + z3d(ji,jj,jk) * zztmp * ( tsn(ji,jj,jk,jp_tem) + tsn(ji,jj+1,jk,jp_tem) ) 
     268                  z2ds(ji,jj) = z2ds(ji,jj) + z3d(ji,jj,jk) * 0.5_wp * ( tsn(ji,jj,jk,jp_sal) + tsn(ji,jj+1,jk,jp_sal) ) 
    221269               END DO 
    222270            END DO 
    223271         END DO 
    224272         CALL lbc_lnk( z2d, 'V', -1. ) 
    225          CALL iom_put( "v_heattr", z2d )                  !  heat transport in i-direction 
    226       ENDIF 
    227       ! 
    228       CALL wrk_dealloc( jpi , jpj      , z2d ) 
     273         CALL lbc_lnk( z2ds, 'V', -1. ) 
     274         CALL iom_put( "v_heattr", z2d )                  !  heat transport in j-direction 
     275         CALL iom_put( "v_salttr", z2ds )                 !  salt transport in j-direction 
     276      ENDIF 
     277      ! 
     278      CALL wrk_dealloc( jpi , jpj      , z2d , z2ds ) 
    229279      CALL wrk_dealloc( jpi , jpj, jpk , z3d ) 
    230280      ! 
Note: See TracChangeset for help on using the changeset viewer.