[3] | 1 | MODULE ldfdyn_oce |
---|
| 2 | !!====================================================================== |
---|
| 3 | !! *** MODULE ldfdyn_oce *** |
---|
| 4 | !! Ocean physics: lateral momentum mixing coefficient defined in memory |
---|
| 5 | !!====================================================================== |
---|
[1601] | 6 | !! History : 1.0 ! 2002-11 (G. Madec) F90: Free form and module |
---|
[3] | 7 | !!---------------------------------------------------------------------- |
---|
[2715] | 8 | USE par_oce ! ocean parameters |
---|
| 9 | USE in_out_manager ! I/O manager |
---|
| 10 | USE lib_mpp ! MPP library |
---|
[3] | 11 | |
---|
| 12 | IMPLICIT NONE |
---|
| 13 | PUBLIC |
---|
| 14 | |
---|
[1601] | 15 | ! !!* Namelist namdyn_ldf : lateral mixing * |
---|
| 16 | LOGICAL , PUBLIC :: ln_dynldf_lap = .TRUE. !: laplacian operator |
---|
| 17 | LOGICAL , PUBLIC :: ln_dynldf_bilap = .FALSE. !: bilaplacian operator |
---|
| 18 | LOGICAL , PUBLIC :: ln_dynldf_level = .FALSE. !: iso-level direction |
---|
| 19 | LOGICAL , PUBLIC :: ln_dynldf_hor = .TRUE. !: horizontal (geopotential) direction |
---|
| 20 | LOGICAL , PUBLIC :: ln_dynldf_iso = .FALSE. !: iso-neutral direction |
---|
[2528] | 21 | REAL(wp), PUBLIC :: rn_ahm_0_lap = 40000._wp !: lateral laplacian eddy viscosity (m2/s) |
---|
| 22 | REAL(wp), PUBLIC :: rn_ahmb_0 = 0._wp !: lateral laplacian background eddy viscosity (m2/s) |
---|
| 23 | REAL(wp), PUBLIC :: rn_ahm_0_blp = 0._wp !: lateral bilaplacian eddy viscosity (m4/s) |
---|
[2715] | 24 | REAL(wp), PUBLIC :: ahm0, ahmb0, ahm0_blp !: OLD namelist names |
---|
[3] | 25 | |
---|
[2715] | 26 | ! !!! eddy coeff. at U-,V-,W-pts [m2/s] |
---|
[3] | 27 | #if defined key_dynldf_c3d |
---|
[2715] | 28 | REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:,:) :: ahm1, ahm2, ahm3, ahm4 !: ** 3D coefficients ** |
---|
[3] | 29 | #elif defined key_dynldf_c2d |
---|
[2715] | 30 | REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:) :: ahm1, ahm2, ahm3, ahm4 !: ** 2D coefficients ** |
---|
[3] | 31 | #elif defined key_dynldf_c1d |
---|
[2715] | 32 | REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:) :: ahm1, ahm2, ahm3, ahm4 !: ** 2D coefficients ** |
---|
[3] | 33 | #else |
---|
[2715] | 34 | REAL(wp), PUBLIC :: ahm1, ahm2, ahm3, ahm4 !: ** 0D coefficients ** |
---|
[3] | 35 | #endif |
---|
| 36 | |
---|
[3211] | 37 | !! * Control permutation of array indices |
---|
| 38 | # include "ldfdyn_oce_ftrans.h90" |
---|
| 39 | |
---|
[3] | 40 | !!---------------------------------------------------------------------- |
---|
[2715] | 41 | !! NEMO/OPA 4.0 , NEMO Consortium (2011) |
---|
[1601] | 42 | !! $Id$ |
---|
[2715] | 43 | !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt) |
---|
| 44 | !!---------------------------------------------------------------------- |
---|
| 45 | CONTAINS |
---|
| 46 | |
---|
| 47 | INTEGER FUNCTION ldfdyn_oce_alloc() |
---|
| 48 | !!---------------------------------------------------------------------- |
---|
| 49 | !! *** FUNCTION ldfdyn_oce_alloc *** |
---|
| 50 | !!---------------------------------------------------------------------- |
---|
| 51 | ldfdyn_oce_alloc = 0 |
---|
| 52 | #if defined key_dynldf_c3d |
---|
| 53 | ALLOCATE( ahm1(jpi,jpj,jpk) , ahm2(jpi,jpj,jpk) , ahm3(jpi,jpj,jpk) , ahm4(jpi,jpj,jpk) , STAT=ldfdyn_oce_alloc ) |
---|
| 54 | #elif defined key_dynldf_c2d |
---|
| 55 | ALLOCATE( ahm1(jpi,jpj ) , ahm2(jpi,jpj ) , ahm3(jpi,jpj ) , ahm4(jpi,jpj ) , STAT=ldfdyn_oce_alloc ) |
---|
| 56 | #elif defined key_dynldf_c1d |
---|
| 57 | ALLOCATE( ahm1( jpk) , ahm2( jpk) , ahm3( jpk) , ahm4( jpk) , STAT=ldfdyn_oce_alloc ) |
---|
| 58 | #endif |
---|
| 59 | IF( ldfdyn_oce_alloc /= 0 ) CALL ctl_warn('ldfdyn_oce_alloc: failed to allocate arrays') |
---|
| 60 | ! |
---|
| 61 | END FUNCTION ldfdyn_oce_alloc |
---|
| 62 | |
---|
[1601] | 63 | !!====================================================================== |
---|
[3] | 64 | END MODULE ldfdyn_oce |
---|