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 10785 for NEMO/releases/release-4.0/src/ICE/icedyn_adv_umx.F90 – NEMO

Ignore:
Timestamp:
2019-03-20T19:58:40+01:00 (5 years ago)
Author:
clem
Message:

fix tickets #2256 and #2257

File:
1 edited

Legend:

Unmodified
Added
Removed
  • NEMO/releases/release-4.0/src/ICE/icedyn_adv_umx.F90

    r10579 r10785  
    2323   ! 
    2424   USE in_out_manager ! I/O manager 
     25   USE iom            ! I/O manager library 
    2526   USE lib_mpp        ! MPP library 
    2627   USE lib_fortran    ! fortran utilities (glob_sum + no signed zero) 
     
    160161          
    161162         zamsk = 1._wp 
    162          CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, pa_i, pa_i, zua_ho, zva_ho ) ! Ice area 
     163         CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, pa_i, pa_i, zua_ho, zva_ho ) !-- Ice area 
    163164         zamsk = 0._wp 
    164165         ! 
    165166         zhvar(:,:,:) = pv_i(:,:,:) * z1_ai(:,:,:) 
    166          CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_i )                ! Ice volume 
     167         CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_i )                !-- Ice volume 
    167168         ! 
    168169         zhvar(:,:,:) = pv_s(:,:,:) * z1_ai(:,:,:) 
    169          CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_s )                ! Snw volume 
     170         CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_s )                !-- Snw volume 
    170171         ! 
    171172         zhvar(:,:,:) = psv_i(:,:,:) * z1_ai(:,:,:) 
    172          CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, psv_i )               ! Salt content 
    173          ! 
    174          zhvar(:,:,:) = poa_i(:,:,:) * z1_ai(:,:,:) 
    175          CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, poa_i )               ! Age content 
     173         CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, psv_i )               !-- Salt content 
    176174         ! 
    177175         DO jk = 1, nlay_i 
    178176            zhvar(:,:,:) = pe_i(:,:,jk,:) * z1_ai(:,:,:) 
    179             CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pe_i(:,:,jk,:) )   ! Ice heat content 
     177            CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pe_i(:,:,jk,:) )   !-- Ice heat content 
    180178         END DO 
    181179         ! 
    182180         DO jk = 1, nlay_s 
    183181            zhvar(:,:,:) = pe_s(:,:,jk,:) * z1_ai(:,:,:) 
    184             CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pe_s(:,:,jk,:) )   ! Snw heat content 
    185          END DO 
    186          ! 
    187          IF ( ln_pnd_H12 ) THEN 
     182            CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pe_s(:,:,jk,:) )   !-- Snw heat content 
     183         END DO 
     184         ! 
     185         IF( iom_use('iceage') .OR. iom_use('iceage_cat') ) THEN                                                              !-- Ice Age 
     186            ! clem: in theory we should use the formulation below to advect the ice age, but the code is unable to deal with 
     187            !       fields that do not depend on volume (here oa_i depends on concentration). It creates abnormal ages that 
     188            !       spread into the domain. Therefore we cheat and consider that ice age should be advected as ice concentration 
     189            !!zhvar(:,:,:) = poa_i(:,:,:) * z1_ai(:,:,:) 
     190            !!CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, poa_i ) 
     191            ! set u*a=u for advection of ice age 
     192            DO jl = 1, jpl 
     193               zua_ho(:,:,jl) = zudy(:,:) 
     194               zva_ho(:,:,jl) = zvdx(:,:) 
     195            END DO 
     196            zamsk = 1._wp 
     197            CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, poa_i, poa_i ) 
     198            zamsk = 0._wp 
     199         ENDIF 
     200         ! 
     201         IF ( ln_pnd_H12 ) THEN                                                                                               !-- melt ponds 
    188202            ! set u*a=u for advection of Ap only  
    189203            DO jl = 1, jpl 
     
    191205               zva_ho(:,:,jl) = zvdx(:,:) 
    192206            END DO 
    193              
     207            ! 
    194208            zamsk = 1._wp 
    195             CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, pa_ip, pa_ip, zua_ho, zva_ho ) ! mp fraction 
     209            CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, pa_ip, pa_ip, zua_ho, zva_ho ) ! fraction 
    196210            zamsk = 0._wp 
    197211            ! 
    198212            zhvar(:,:,:) = pv_ip(:,:,:) * z1_aip(:,:,:) 
    199             CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_ip )                 ! mp volume 
     213            CALL adv_umx( zamsk, kn_umx, jt, kt, zdt, zudy, zvdx, zua_ho, zva_ho, zcu_box, zcv_box, zhvar, pv_ip )                 ! volume 
    200214         ENDIF 
    201215         ! 
     
    203217         DO jj = 2, jpjm1 
    204218            DO ji = fs_2, fs_jpim1 
    205                pato_i(ji,jj) = pato_i(ji,jj) - ( zati2(ji,jj) - zati1(ji,jj) ) &                                                   ! Open water area 
     219               pato_i(ji,jj) = pato_i(ji,jj) - ( zati2(ji,jj) - zati1(ji,jj) ) &                                              !-- Open water area 
    206220                  &                          - ( zudy(ji,jj) - zudy(ji-1,jj) + zvdx(ji,jj) - zvdx(ji,jj-1) ) * r1_e1e2t(ji,jj) * zdt 
    207221            END DO 
Note: See TracChangeset for help on using the changeset viewer.