source: LMDZ6/trunk/libf/phylmd/ecrad-acc/ifsrrtm/srtm_cmbgb19.F90

Last change on this file was 6016, checked in by yann meurdesoif, 3 months ago

Add new ecrad version from DWD ported onto OpenACC, closed from original ecrad ECMWF starting point for LMDZ ecrad version.

Modification from ecrad-lmdz version has been included.

YM

  • Property svn:eol-style set to native
File size: 2.2 KB
Line 
1! This file has been modified for the use in ICON
2
3SUBROUTINE SRTM_CMBGB19
4
5!     BAND 19:  4650-5150 cm-1 (low - H2O,CO2; high - CO2)
6!-----------------------------------------------------------------------
7
8USE PARKIND1  ,ONLY : JPIM , JPRB
9USE YOMHOOK   ,ONLY : LHOOK, DR_HOOK, JPHOOK
10
11USE YOESRTM  , ONLY : NGN
12USE YOESRTWN , ONLY : NGC, NGS, RWGT
13!USE YOESRTWN , ONLY : NGC, NGS, NGN, RWGT
14USE YOESRTA19, ONLY : KA, KB, SELFREF, FORREF, SFLUXREF, &
15                    & KAC, KBC, SELFREFC, FORREFC, SFLUXREFC
16
17IMPLICIT NONE
18
19! Local variables
20INTEGER(KIND=JPIM) :: JN, JT, JP, IGC, IPR, IPRSM
21REAL(KIND=JPRB)    :: ZSUMK, ZSUMF
22
23REAL(KIND=JPHOOK) :: ZHOOK_HANDLE
24!     ------------------------------------------------------------------
25IF (LHOOK) CALL DR_HOOK('SRTM_CMBGB19',0,ZHOOK_HANDLE)
26
27DO JN = 1,9
28  DO JT = 1,5
29    DO JP = 1,13
30      IPRSM = 0
31      DO IGC = 1,NGC(4)
32        ZSUMK = 0.
33        DO IPR = 1, NGN(NGS(3)+IGC)
34          IPRSM = IPRSM + 1
35          ZSUMK = ZSUMK + KA(JN,JT,JP,IPRSM)*RWGT(IPRSM+48)
36        ENDDO
37        KAC(JN,JT,JP,IGC) = ZSUMK
38      ENDDO
39    ENDDO
40  ENDDO
41ENDDO
42
43DO JT = 1,5
44  DO JP = 13,59
45    IPRSM = 0
46    DO IGC = 1,NGC(4)
47      ZSUMK = 0.
48      DO IPR = 1, NGN(NGS(3)+IGC)
49        IPRSM = IPRSM + 1
50        ZSUMK = ZSUMK + KB(JT,JP,IPRSM)*RWGT(IPRSM+48)
51      ENDDO
52      KBC(JT,JP,IGC) = ZSUMK
53    ENDDO
54  ENDDO
55ENDDO
56
57DO JT = 1,10
58  IPRSM = 0
59  DO IGC = 1,NGC(4)
60    ZSUMK = 0.
61    DO IPR = 1, NGN(NGS(3)+IGC)
62      IPRSM = IPRSM + 1
63      ZSUMK = ZSUMK + SELFREF(JT,IPRSM)*RWGT(IPRSM+48)
64    ENDDO
65    SELFREFC(JT,IGC) = ZSUMK
66  ENDDO
67ENDDO
68
69DO JT = 1,3
70  IPRSM = 0
71  DO IGC = 1,NGC(4)
72    ZSUMK = 0.
73    DO IPR = 1, NGN(NGS(3)+IGC)
74      IPRSM = IPRSM + 1
75      ZSUMK = ZSUMK + FORREF(JT,IPRSM)*RWGT(IPRSM+48)
76    ENDDO
77    FORREFC(JT,IGC) = ZSUMK
78  ENDDO
79ENDDO
80
81DO JP = 1,9
82  IPRSM = 0
83  DO IGC = 1,NGC(4)
84    ZSUMF = 0.
85    DO IPR = 1, NGN(NGS(3)+IGC)
86      IPRSM = IPRSM + 1
87      ZSUMF = ZSUMF + SFLUXREF(IPRSM,JP)
88    ENDDO
89    SFLUXREFC(IGC,JP) = ZSUMF
90  ENDDO
91ENDDO
92
93!$ACC UPDATE DEVICE(KAC, KBC, SELFREFC, FORREFC, SFLUXREFC)
94
95!     -----------------------------------------------------------------
96IF (LHOOK) CALL DR_HOOK('SRTM_CMBGB19',1,ZHOOK_HANDLE)
97END SUBROUTINE SRTM_CMBGB19
98
Note: See TracBrowser for help on using the repository browser.