source: LMDZ6/branches/Ocean_skin/libf/phylmd/ecrad/srtm_cmbgb23.F90 @ 5450

Last change on this file since 5450 was 3908, checked in by idelkadi, 4 years ago

Online implementation of the radiative transfer code ECRAD in the LMDZ model.

  • Inclusion of the ecrad directory containing the sources of the ECRAD code
    • interface routine : radiation_scheme.F90
  • Adaptation of compilation scripts :
    • compilation under CPP key CPP_ECRAD
    • compilation with option "-rad ecard" or "-ecard true"
    • The "-rad old/rtm/ecran" build option will need to replace the "-rrtm true" and "-ecrad true" options in the future.
  • Runing LMDZ simulations with ecrad, you need :
    • logical key iflag_rrtm = 2 in physiq.def
    • namelist_ecrad (DefLists?)
    • the directory "data" containing the configuration files is temporarily placed in ../libfphylmd/ecrad/
  • Compilation and execution are tested in the 1D case. The repository under svn would allow to continue the implementation work: tests, verification of the results, ...
File size: 1.8 KB
Line 
1SUBROUTINE SRTM_CMBGB23
2
3!     BAND 23:  8050-12850 cm-1 (low - H2O; high - nothing)
4!-----------------------------------------------------------------------
5
6USE PARKIND1  ,ONLY : JPIM , JPRB
7USE YOMHOOK   ,ONLY : LHOOK, DR_HOOK
8
9USE YOESRTM  , ONLY : NGN
10USE YOESRTWN , ONLY : NGC, NGS, RWGT
11!USE YOESRTWN , ONLY : NGC, NGS, NGN, RWGT
12USE YOESRTA23, ONLY : KA, SELFREF, FORREF, SFLUXREF, RAYL, &
13                    & KAC, SELFREFC, FORREFC, SFLUXREFC, RAYLC
14
15IMPLICIT NONE
16
17! Local variables
18INTEGER(KIND=JPIM) :: JT, JP, IGC, IPR, IPRSM
19REAL(KIND=JPRB)    :: ZSUMK, ZSUMF1, ZSUMF2
20
21REAL(KIND=JPRB) :: ZHOOK_HANDLE
22!     ------------------------------------------------------------------
23IF (LHOOK) CALL DR_HOOK('SRTM_CMBGB23',0,ZHOOK_HANDLE)
24
25DO JT = 1,5
26  DO JP = 1,13
27    IPRSM = 0
28    DO IGC = 1,NGC(8)
29      ZSUMK = 0.
30      DO IPR = 1, NGN(NGS(7)+IGC)
31        IPRSM = IPRSM + 1
32        ZSUMK = ZSUMK + KA(JT,JP,IPRSM)*RWGT(IPRSM+112)
33      ENDDO
34      KAC(JT,JP,IGC) = ZSUMK
35    ENDDO
36  ENDDO
37ENDDO
38
39DO JT = 1,10
40  IPRSM = 0
41  DO IGC = 1,NGC(8)
42    ZSUMK = 0.
43    DO IPR = 1, NGN(NGS(7)+IGC)
44      IPRSM = IPRSM + 1
45      ZSUMK = ZSUMK + SELFREF(JT,IPRSM)*RWGT(IPRSM+112)
46    ENDDO
47    SELFREFC(JT,IGC) = ZSUMK
48  ENDDO
49ENDDO
50
51DO JT = 1,3
52  IPRSM = 0
53  DO IGC = 1,NGC(8)
54    ZSUMK = 0.
55    DO IPR = 1, NGN(NGS(7)+IGC)
56      IPRSM = IPRSM + 1
57      ZSUMK = ZSUMK + FORREF(JT,IPRSM)*RWGT(IPRSM+112)
58    ENDDO
59    FORREFC(JT,IGC) = ZSUMK
60  ENDDO
61ENDDO
62
63IPRSM = 0
64DO IGC = 1,NGC(8)
65  ZSUMF1 = 0.
66  ZSUMF2 = 0.
67  DO IPR = 1, NGN(NGS(7)+IGC)
68    IPRSM = IPRSM + 1
69    ZSUMF1 = ZSUMF1 + SFLUXREF(IPRSM)
70    ZSUMF2 = ZSUMF2 + RAYL(IPRSM)*RWGT(IPRSM+112)
71  ENDDO
72  SFLUXREFC(IGC) = ZSUMF1
73  RAYLC(IGC) = ZSUMF2
74ENDDO
75
76!     -----------------------------------------------------------------
77IF (LHOOK) CALL DR_HOOK('SRTM_CMBGB23',1,ZHOOK_HANDLE)
78END SUBROUTINE SRTM_CMBGB23
79
Note: See TracBrowser for help on using the repository browser.