yom_ygfl.F90 Source File


This file depends on

sourcefile~~yom_ygfl.f90~4~~EfferentGraph sourcefile~yom_ygfl.f90~4 yom_ygfl.F90 sourcefile~parkind1.f90 parkind1.F90 sourcefile~yom_ygfl.f90~4->sourcefile~parkind1.f90 sourcefile~type_gfls.f90 type_gfls.F90 sourcefile~yom_ygfl.f90~4->sourcefile~type_gfls.f90 sourcefile~type_gfls.f90->sourcefile~parkind1.f90

Contents

Source Code


Source Code

MODULE YOM_YGFL

USE PARKIND1  ,ONLY : JPIM     ,JPRB

USE TYPE_GFLS ,ONLY : TYPE_GFLD,TYPE_GFL_COMP,TYPE_GFL_NAML

IMPLICIT NONE
SAVE

!-------------------------------------------------------------------------
! Contains the descriptors of GFL arrays 

! YGFL  : GFL general descriptor, for info about content see comments
!         in type declaration module : type_gfls.F90

! JPGFL : Max number of GFL fields
! JPNAMED_GFL : Number of currently pre-defined components of GFL
! JPGHG : Number of greenhouse gas fields
! JPGRG : Number of reactive gas fields
! JPAERO : Number of aerosol fields
! JPTRAC : Number of tracers for diagnostics
!-------------------------------------------------------------------------

INTEGER(KIND=JPIM),PARAMETER :: JPGFL=211
INTEGER(KIND=JPIM),PARAMETER :: JPNAMED_GFL=22
INTEGER(KIND=JPIM),PARAMETER :: JPGHG=3
INTEGER(KIND=JPIM),PARAMETER :: JPTRAC=2
INTEGER(KIND=JPIM),PARAMETER :: JPGRG=5
INTEGER(KIND=JPIM),PARAMETER :: JPAERO=7
INTEGER(KIND=JPIM),PARAMETER :: JPFORC=25
INTEGER(KIND=JPIM),PARAMETER :: JPEZDIAG=25
INTEGER(KIND=JPIM) :: NGFL_EXT
INTEGER(KIND=JPIM) :: NGFL_FORC
INTEGER(KIND=JPIM) :: NGFL_EZDIAG
INTEGER(KIND=JPIM) :: NGHG
INTEGER(KIND=JPIM) :: NTRAC
INTEGER(KIND=JPIM) :: NGRG
INTEGER(KIND=JPIM) :: NAERO
INTEGER(KIND=JPIM) :: NACTAERO
LOGICAL ::            LGHGSFC, LAEROSFC , LSF6SFC
TYPE(TYPE_GFLD) :: YGFL
TYPE(TYPE_GFL_COMP),TARGET  :: YGFLC(JPGFL)  ! General descriptor of all components

TYPE(TYPE_GFL_COMP),POINTER  :: YQ            ! Specific humidity
TYPE(TYPE_GFL_COMP),POINTER  :: YI            ! Ice water
TYPE(TYPE_GFL_COMP),POINTER  :: YL            ! Liquid water
TYPE(TYPE_GFL_COMP),POINTER  :: YS            ! Snow
TYPE(TYPE_GFL_COMP),POINTER  :: YR            ! Rain
TYPE(TYPE_GFL_COMP),POINTER  :: YG            ! Graupels
TYPE(TYPE_GFL_COMP),POINTER  :: YTKE          ! Turbulent Kinetic Energy
TYPE(TYPE_GFL_COMP),POINTER  :: YA            ! Cloud fraction
TYPE(TYPE_GFL_COMP),POINTER  :: YO3           ! Ozone
TYPE(TYPE_GFL_COMP),POINTER  :: YSRC          ! Second-order flux for AROME
                                              ! s'rc'/2Sigma_s2 
                                              ! multiplied by Lambda_3
TYPE(TYPE_GFL_COMP),POINTER  :: YCPF          ! Convective precipitation flux
TYPE(TYPE_GFL_COMP),POINTER  :: YSPF          ! Stratiform precipitation flux
TYPE(TYPE_GFL_COMP),POINTER  :: YCVGQ         ! Moisture Convergence for french physics
TYPE(TYPE_GFL_COMP),POINTER  :: YQVA          ! total humidity variation
TYPE(TYPE_GFL_COMP),POINTER  :: YGHG(:)       ! Greenhouse Gases
TYPE(TYPE_GFL_COMP),POINTER  :: YGRG(:)       ! Reactive Gases
TYPE(TYPE_GFL_COMP),POINTER  :: YAERO(:)      ! Aerosols
TYPE(TYPE_GFL_COMP),POINTER  :: YTRAC(:)      ! tracers for diagnostics
TYPE(TYPE_GFL_COMP),POINTER  :: YFORC(:)      ! large scale forcing
TYPE(TYPE_GFL_COMP),POINTER  :: YEZDIAG(:)    ! easy diagnostics

TYPE(TYPE_GFL_COMP),POINTER  :: YSDSAT        ! Standard Deviation of the
                                              ! SATuration Depression (Sigma_s) 
TYPE(TYPE_GFL_COMP),POINTER  :: YCVV          ! Convective Vertical Velocity 

! Prognostic convection variables: add 6 named components
TYPE(TYPE_GFL_COMP),POINTER  :: YUOM          ! Updraught vert velocity
TYPE(TYPE_GFL_COMP),POINTER  :: YUAL          ! Updraught mesh fraction
TYPE(TYPE_GFL_COMP),POINTER  :: YDOM          ! Downdraught vert velocity
TYPE(TYPE_GFL_COMP),POINTER  :: YDAL          ! Downdraught mesh fraction
TYPE(TYPE_GFL_COMP),POINTER  :: YUEN          ! Updraught entrainment
TYPE(TYPE_GFL_COMP),POINTER  :: YUNEBH        ! pseudo-historic convective

! Extra fields 

TYPE(TYPE_GFL_COMP),POINTER  :: YEXT(:)       ! Extra fields

TYPE(TYPE_GFL_NAML)  :: YQ_NL            ! Specific humidity
TYPE(TYPE_GFL_NAML)  :: YI_NL            ! Ice water
TYPE(TYPE_GFL_NAML)  :: YL_NL            ! Liquid water
TYPE(TYPE_GFL_NAML)  :: YS_NL            ! Snow
TYPE(TYPE_GFL_NAML)  :: YR_NL            ! Rain
TYPE(TYPE_GFL_NAML)  :: YG_NL            ! Graupels
TYPE(TYPE_GFL_NAML)  :: YTKE_NL          ! Turbulent Kinetic Energy
TYPE(TYPE_GFL_NAML)  :: YA_NL            ! Cloud fraction
TYPE(TYPE_GFL_NAML)  :: YO3_NL           ! Ozone
TYPE(TYPE_GFL_NAML)  :: YSRC_NL          ! Second-order flux for AROME
                                         ! s'rc'/2Sigma_s2
                                         ! multiplied by Lambda_3
TYPE(TYPE_GFL_NAML)  :: YCPF_NL          ! Convective precipitation flux
TYPE(TYPE_GFL_NAML)  :: YSPF_NL          ! Stratiform precipitation flux
TYPE(TYPE_GFL_NAML)  :: YCVGQ_NL         ! Moisture Convergence for french physics
TYPE(TYPE_GFL_NAML)  :: YQVA_NL          ! Total humidity variation

TYPE(TYPE_GFL_NAML)  :: YGHG_NL(JPGHG)   ! Greenhouse Gases
TYPE(TYPE_GFL_NAML)  :: YGRG_NL(JPGRG)   ! Reactive Gases
TYPE(TYPE_GFL_NAML)  :: YAERO_NL(JPAERO) ! Aerosol fields
TYPE(TYPE_GFL_NAML)  :: YTRAC_NL(JPTRAC)   ! Tracers for diagnostics

! Extra fields 

TYPE(TYPE_GFL_NAML)  :: YSDSAT_NL        ! Standard Deviation of the
                                         ! SATuration Depression (Sigma_s) 
TYPE(TYPE_GFL_NAML)  :: YCVV_NL          ! Convective Vertical Velocity 
TYPE(TYPE_GFL_NAML)  :: YFORC_NL(JPFORC) ! Forcing precursor
TYPE(TYPE_GFL_NAML)  :: YEZDIAG_NL(JPEZDIAG) ! Easy diagnostics
TYPE(TYPE_GFL_NAML)  :: YEXT_NL(JPGFL-JPNAMED_GFL-JPGHG-JPGRG-JPFORC-JPEZDIAG-JPAERO-JPTRAC) ! Extra fields

! Prognostic convection variables: 6 more namelist components
TYPE(TYPE_GFL_NAML)  :: YUOM_NL          ! Updraught vert velocity
TYPE(TYPE_GFL_NAML)  :: YUAL_NL          ! Updraught mesh fraction
TYPE(TYPE_GFL_NAML)  :: YDOM_NL          ! Downdraught vert velocity
TYPE(TYPE_GFL_NAML)  :: YDAL_NL          ! Downdraught mesh fraction
TYPE(TYPE_GFL_NAML)  :: YUEN_NL          ! Updraught entrainment
TYPE(TYPE_GFL_NAML)  :: YUNEBH_NL        ! Pseudi Hist Conv cloud fraction

!------------------------------------------------------------------
!$OMP THREADPRIVATE(laerosfc,lghgsfc,lsf6sfc,nactaero,naero,ngfl_ext,ngfl_ezdiag,ngfl_forc,nghg,ngrg)
!$OMP THREADPRIVATE(ntrac,ya,ya_nl,yaero,yaero_nl,ycpf,ycpf_nl,ycvgq,ycvgq_nl,ycvv,ycvv_nl,ydal,ydal_nl)
!$OMP THREADPRIVATE(ydom,ydom_nl,yext,yext_nl,yezdiag,yezdiag_nl,yforc,yforc_nl,yg,yg_nl,ygfl,ygflc,yghg)
!$OMP THREADPRIVATE(yghg_nl,ygrg,ygrg_nl,yi,yi_nl,yl,yl_nl,yo3,yo3_nl,yq,yq_nl,yqva,yqva_nl,yr,yr_nl,ys)
!$OMP THREADPRIVATE(ys_nl,ysdsat,ysdsat_nl,yspf,yspf_nl,ysrc,ysrc_nl,ytke,ytke_nl,ytrac,ytrac_nl,yual)
!$OMP THREADPRIVATE(yual_nl,yuen,yuen_nl,yunebh,yunebh_nl,yuom,yuom_nl)
END MODULE YOM_YGFL