ltdir_mod.F90 Source File


This file depends on

sourcefile~~ltdir_mod.f90~2~~EfferentGraph sourcefile~ltdir_mod.f90~2 ltdir_mod.F90 sourcefile~cdmap_mod.f90 cdmap_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~cdmap_mod.f90 sourcefile~ldfou2_mod.f90 ldfou2_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~ldfou2_mod.f90 sourcefile~ledir_mod.f90 ledir_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~ledir_mod.f90 sourcefile~prepsnm_mod.f90 prepsnm_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~prepsnm_mod.f90 sourcefile~prfi2_mod.f90 prfi2_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~prfi2_mod.f90 sourcefile~tpm_dim.f90 tpm_dim.F90 sourcefile~ltdir_mod.f90~2->sourcefile~tpm_dim.f90 sourcefile~tpm_fields.f90 tpm_fields.F90 sourcefile~ltdir_mod.f90~2->sourcefile~tpm_fields.f90 sourcefile~tpm_flt.f90 tpm_flt.F90 sourcefile~ltdir_mod.f90~2->sourcefile~tpm_flt.f90 sourcefile~tpm_geometry.f90 tpm_geometry.F90 sourcefile~ltdir_mod.f90~2->sourcefile~tpm_geometry.f90 sourcefile~tpm_trans.f90 tpm_trans.F90 sourcefile~ltdir_mod.f90~2->sourcefile~tpm_trans.f90 sourcefile~updsp_mod.f90 updsp_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~updsp_mod.f90 sourcefile~uvtvd_mod.f90 uvtvd_mod.F90 sourcefile~ltdir_mod.f90~2->sourcefile~uvtvd_mod.f90 sourcefile~cdmap_mod.f90->sourcefile~tpm_flt.f90 sourcefile~cdmap_mod.f90->sourcefile~tpm_geometry.f90 sourcefile~cdmap_mod.f90->sourcefile~tpm_trans.f90 sourcefile~parkind_ectrans.f90 parkind_ectrans.F90 sourcefile~cdmap_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~seefmm_mix.f90 seefmm_mix.F90 sourcefile~cdmap_mod.f90->sourcefile~seefmm_mix.f90 sourcefile~tpm_distr.f90 tpm_distr.F90 sourcefile~cdmap_mod.f90->sourcefile~tpm_distr.f90 sourcefile~ldfou2_mod.f90->sourcefile~tpm_dim.f90 sourcefile~ldfou2_mod.f90->sourcefile~tpm_fields.f90 sourcefile~ldfou2_mod.f90->sourcefile~tpm_geometry.f90 sourcefile~ledir_mod.f90->sourcefile~tpm_dim.f90 sourcefile~ledir_mod.f90->sourcefile~tpm_fields.f90 sourcefile~ledir_mod.f90->sourcefile~tpm_geometry.f90 sourcefile~buffered_allocator_mod.f90 buffered_allocator_mod.F90 sourcefile~ledir_mod.f90->sourcefile~buffered_allocator_mod.f90 sourcefile~hicblas_mod.f90 hicblas_mod.F90 sourcefile~ledir_mod.f90->sourcefile~hicblas_mod.f90 sourcefile~ledir_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~ledir_mod.f90->sourcefile~tpm_distr.f90 sourcefile~tpm_gen.f90 tpm_gen.F90 sourcefile~ledir_mod.f90->sourcefile~tpm_gen.f90 sourcefile~tpm_stats.f90 tpm_stats.F90 sourcefile~ledir_mod.f90->sourcefile~tpm_stats.f90 sourcefile~prepsnm_mod.f90->sourcefile~tpm_dim.f90 sourcefile~prepsnm_mod.f90->sourcefile~tpm_fields.f90 sourcefile~prepsnm_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~prepsnm_mod.f90->sourcefile~tpm_distr.f90 sourcefile~prepsnm_mod.f90->sourcefile~tpm_gen.f90 sourcefile~prfi2b_mod.f90 prfi2b_mod.F90 sourcefile~prfi2_mod.f90->sourcefile~prfi2b_mod.f90 sourcefile~tpm_fields.f90->sourcefile~parkind_ectrans.f90 sourcefile~tpm_flt.f90->sourcefile~parkind_ectrans.f90 sourcefile~tpm_flt.f90->sourcefile~seefmm_mix.f90 sourcefile~tpm_geometry.f90->sourcefile~parkind_ectrans.f90 sourcefile~growing_allocator_mod.f90 growing_allocator_mod.F90 sourcefile~tpm_trans.f90->sourcefile~growing_allocator_mod.f90 sourcefile~tpm_trans.f90->sourcefile~parkind_ectrans.f90 sourcefile~updsp_mod.f90->sourcefile~tpm_trans.f90 sourcefile~updsp_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~updsp_mod.f90->sourcefile~tpm_distr.f90 sourcefile~updspb_mod.f90 updspb_mod.F90 sourcefile~updsp_mod.f90->sourcefile~updspb_mod.f90 sourcefile~uvtvd_mod.f90->sourcefile~tpm_dim.f90 sourcefile~uvtvd_mod.f90->sourcefile~tpm_fields.f90 sourcefile~uvtvd_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~uvtvd_mod.f90->sourcefile~tpm_distr.f90 sourcefile~buffered_allocator_mod.f90->sourcefile~growing_allocator_mod.f90 sourcefile~buffered_allocator_mod.f90->sourcefile~parkind_ectrans.f90 sourcefile~abort_trans_mod.f90 abort_trans_mod.F90 sourcefile~buffered_allocator_mod.f90->sourcefile~abort_trans_mod.f90 sourcefile~hicblas_mod.f90->sourcefile~growing_allocator_mod.f90 sourcefile~prfi2b_mod.f90->sourcefile~tpm_dim.f90 sourcefile~prfi2b_mod.f90->sourcefile~tpm_geometry.f90 sourcefile~prfi2b_mod.f90->sourcefile~tpm_trans.f90 sourcefile~prfi2b_mod.f90->sourcefile~tpm_distr.f90 sourcefile~seefmm_mix.f90->sourcefile~parkind_ectrans.f90 sourcefile~wts500_mod.f90 wts500_mod.F90 sourcefile~seefmm_mix.f90->sourcefile~wts500_mod.f90 sourcefile~tpm_gen.f90->sourcefile~parkind_ectrans.f90 sourcefile~tpm_stats.f90->sourcefile~parkind_ectrans.f90 sourcefile~updspb_mod.f90->sourcefile~tpm_dim.f90 sourcefile~updspb_mod.f90->sourcefile~tpm_distr.f90 sourcefile~abort_trans_mod.f90->sourcefile~tpm_distr.f90 sourcefile~abort_trans_mod.f90->sourcefile~tpm_gen.f90 sourcefile~wts500_mod.f90->sourcefile~parkind_ectrans.f90

Source Code

! (C) Copyright 1987- ECMWF.
! (C) Copyright 1987- Meteo-France.
! 
! This software is licensed under the terms of the Apache Licence Version 2.0
! which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
! In applying this licence, ECMWF does not waive the privileges and immunities
! granted to it by virtue of its status as an intergovernmental organisation
! nor does it submit to any jurisdiction.
!

MODULE LTDIR_MOD
CONTAINS
SUBROUTINE LTDIR(KM,KMLOC,KF_FS,KF_UV,KF_SCALARS,KLED2,&
 & PSPVOR,PSPDIV,PSPSCALAR,&
 & PSPSC3A,PSPSC3B,PSPSC2 , &
 & KFLDPTRUV,KFLDPTRSC)


USE PARKIND1  ,ONLY : JPIM     ,JPRB
USE YOMHOOK   ,ONLY : LHOOK,   DR_HOOK, JPHOOK

USE TPM_DIM         ,ONLY : R
USE TPM_FIELDS      ,ONLY : F
USE TPM_TRANS, ONLY : LATLON
USE TPM_FLT         ,ONLY : S
USE TPM_GEOMETRY    ,ONLY : G

USE PREPSNM_MOD     ,ONLY : PREPSNM
USE PRFI2_MOD       ,ONLY : PRFI2
USE LDFOU2_MOD      ,ONLY : LDFOU2
USE LEDIR_MOD       ,ONLY : LEDIR
USE UVTVD_MOD       ,ONLY : UVTVD      
USE UPDSP_MOD       ,ONLY : UPDSP
USE CDMAP_MOD , ONLY : CDMAP

!**** *LTDIR* - Control of Direct Legendre transform step

!     Purpose.
!     --------
!        Tranform from Fourier space to spectral space, compute
!        vorticity and divergence.

!**   Interface.
!     ----------
!        *CALL* *LTDIR(...)*

!        Explicit arguments :
!        --------------------  KM     - zonal wavenumber
!                              KMLOC  - local zonal wavenumber

!        Implicit arguments :  None
!        --------------------

!     Method.
!     -------

!     Externals.
!     ----------
!         PREPSNM - prepare REPSNM for wavenumber KM
!         PRFI2   - prepares the Fourier work arrays for model variables.
!         LDFOU2  - computations in Fourier space
!         LEDIR   - direct Legendre transform
!         UVTVD   -
!         UPDSP   - updating of spectral arrays (fields)

!     Reference.
!     ----------
!        ECMWF Research Department documentation of the IFS

!     Author.
!     -------
!        Mats Hamrud and Philippe Courtier  *ECMWF*

!     Modifications.
!     --------------
!        Original : 87-11-24
!        Modified : 91-07-01 Philippe Courtier/Mats Hamrud - Rewrite
!                            for uv formulation
!        Modified 93-03-19 D. Giard - CDCONF='T' for tendencies
!        Modified 93-11-18 M. Hamrud - use only one Fourier buffer
!        Modified 94-04-06 R. El khatib Full-POS implementation
!        M.Hamrud  : 94-11-01 New conf 'G' - vor,div->vor,div
!                             instead of u,v->vor,div
!        MPP Group : 95-10-01 Support for Distributed Memory version
!        K. YESSAD (AUGUST 1996):
!               - Legendre transforms for transmission coefficients.
!        Modified : 04/06/99 D.Salmond : change order of AIA and SIA
!        R. El Khatib 12-Jul-2012 LDSPC2 replaced by UVTVD
!     ------------------------------------------------------------------

IMPLICIT NONE


!     DUMMY INTEGER SCALARS
INTEGER(KIND=JPIM), INTENT(IN)  :: KM
INTEGER(KIND=JPIM), INTENT(IN)  :: KMLOC
INTEGER(KIND=JPIM),INTENT(IN)   :: KF_FS,KF_UV,KF_SCALARS,KLED2

REAL(KIND=JPRB)  ,OPTIONAL, INTENT(OUT) :: PSPVOR(:,:)
REAL(KIND=JPRB)  ,OPTIONAL, INTENT(OUT) :: PSPDIV(:,:)
REAL(KIND=JPRB)  ,OPTIONAL, INTENT(OUT) :: PSPSCALAR(:,:)
REAL(KIND=JPRB)   ,OPTIONAL,INTENT(OUT) :: PSPSC2(:,:)
REAL(KIND=JPRB)   ,OPTIONAL,INTENT(OUT) :: PSPSC3A(:,:,:)
REAL(KIND=JPRB)   ,OPTIONAL,INTENT(OUT) :: PSPSC3B(:,:,:)
INTEGER(KIND=JPIM),OPTIONAL,INTENT(IN)  :: KFLDPTRUV(:)
INTEGER(KIND=JPIM),OPTIONAL,INTENT(IN)  :: KFLDPTRSC(:)


!     LOCAL INTEGER SCALARS
INTEGER(KIND=JPIM) :: IFC, IIFC, IDGLU
INTEGER(KIND=JPIM) :: IUS, IUE, IVS, IVE, IVORS, IVORE, IDIVS, IDIVE
INTEGER(KIND=JPIM) :: ISL, ISLO

!     LOCAL REALS
!REAL(KIND=JPRB) :: ZSIA(KLED2,R%NDGNH),       ZAIA(KLED2,R%NDGNH)
REAL(KIND=JPRB) :: ZEPSNM(0:R%NTMAX+2)
REAL(KIND=JPRB) :: ZOA1(R%NLED4,KLED2),         ZOA2(R%NLED4,MAX(4*KF_UV,1))
REAL(KIND=JPRB), ALLOCATABLE :: ZAIA(:,:), ZSIA(:,:)

REAL(KIND=JPHOOK) :: ZHOOK_HANDLE

!     ------------------------------------------------------------------
IF (LHOOK) CALL DR_HOOK('LTDIR_MOD',0,ZHOOK_HANDLE)
!     ------------------------------------------------------------------

!*       4.    DIRECT LEGENDRE TRANSFORM.
!              --------------------------
IFC = 2*KF_FS
IIFC = IFC
IF(KM == 0)THEN
  IIFC = IFC/2
ENDIF

IDGLU = MIN(R%NDGNH,G%NDGLU(KM))
ISL = MAX(R%NDGNH-G%NDGLU(KM)+1,1)

ALLOCATE(ZSIA(KLED2,R%NDGNH))
ALLOCATE(ZAIA(KLED2,R%NDGNH))

IF( LATLON.AND.S%LDLL ) THEN

  IF( (S%LSHIFTLL .AND. KM < 2*IDGLU) .OR.&
   & (.NOT.S%LSHIFTLL .AND. KM < 2*(IDGLU-1)) ) THEN

    CALL PREPSNM(KM,KMLOC,ZEPSNM)
    ISLO = S%FA(KMLOC)%ISLD
    ! map from external to internal (gg) roots and split into anti-symmetric / symmetric
    CALL CDMAP(KM,KMLOC,ISL,ISLO,ZEPSNM(R%NTMAX+1),1_JPIM,&
     & R%NDGNH,S%NDGNHD,IFC,ZAIA,ZSIA)

  ENDIF

ELSE

  CALL PRFI2(KM,KMLOC,KF_FS,ZAIA,ZSIA)

ENDIF

CALL LDFOU2(KM,KF_UV,ZAIA,ZSIA)

CALL LEDIR(KM,KMLOC,IFC,IIFC,ISL,IDGLU,KLED2,ZAIA,ZSIA,ZOA1,F%RW(1:R%NDGNH))

DEALLOCATE(ZAIA)
DEALLOCATE(ZSIA)

!     ------------------------------------------------------------------

!*       5.    COMPUTE VORTICITY AND DIVERGENCE.
!              ---------------------------------

IF( KF_UV > 0 ) THEN
  CALL PREPSNM(KM,KMLOC,ZEPSNM)
  IUS = 1
  IUE = 2*KF_UV
  IVS = 2*KF_UV+1
  IVE = 4*KF_UV
  IVORS = 1
  IVORE = 2*KF_UV
  IDIVS = 2*KF_UV+1
  IDIVE = 4*KF_UV
  CALL UVTVD(KM,KF_UV,ZEPSNM,ZOA1(:,IUS:IUE),ZOA1(:,IVS:IVE),&
   & ZOA2(:,IVORS:IVORE),ZOA2(:,IDIVS:IDIVE))
ENDIF

!     ------------------------------------------------------------------

!*       6.    UPDATE SPECTRAL ARRAYS.
!              -----------------------

CALL UPDSP(KM,KF_UV,KF_SCALARS,ZOA1,ZOA2, &
 & PSPVOR,PSPDIV,PSPSCALAR,&
 & PSPSC3A,PSPSC3B,PSPSC2 , &
 & KFLDPTRUV,KFLDPTRSC)

!     ------------------------------------------------------------------
IF (LHOOK) CALL DR_HOOK('LTDIR_MOD',1,ZHOOK_HANDLE)

END SUBROUTINE LTDIR
END MODULE LTDIR_MOD