[2027] | 1 | ! |
---|
| 2 | ! $Id: srtm_srtm_224gp.F90 5294 2024-10-29 18:35:00Z fhourdin $ |
---|
| 3 | ! |
---|
[1989] | 4 | SUBROUTINE SRTM_SRTM_224GP & |
---|
| 5 | & ( KIDIA , KFDIA , KLON , KLEV , KSW , KOVLP ,& |
---|
| 6 | & PAER , PALBD , PALBP , PAPH , PAP ,& |
---|
| 7 | & PTS , PTH , PT ,& |
---|
| 8 | & PQ , PCCO2 , POZN , PRMU0 ,& |
---|
| 9 | & PFRCL , PTAUC , PASYC , POMGC ,& |
---|
| 10 | & PALBT , PFSUX , PFSUC & |
---|
| 11 | & ) |
---|
| 12 | |
---|
| 13 | !-- interface to RRTM_SW |
---|
| 14 | ! JJMorcrette 030225 |
---|
| 15 | |
---|
| 16 | USE PARKIND1 ,ONLY : JPIM ,JPRB |
---|
| 17 | USE YOMHOOK ,ONLY : LHOOK, DR_HOOK |
---|
| 18 | |
---|
| 19 | USE PARSRTM , ONLY : JPLAY |
---|
[2027] | 20 | !USE YOERDI , ONLY : RCH4 , RN2O |
---|
[1989] | 21 | USE YOERAD , ONLY : NAER |
---|
| 22 | USE YOESRTAER, ONLY : RSRTAUA, RSRPIZA, RSRASYA |
---|
| 23 | USE YOMPHY3 , ONLY : RII0 |
---|
| 24 | USE YOMCST , ONLY : RI0 |
---|
[5294] | 25 | ! Temporary fix waiting for cleaner interface (or not) |
---|
| 26 | USE clesphys_mod_h, ONLY: NSW, rch4, rn2o |
---|
[1989] | 27 | |
---|
[2027] | 28 | |
---|
[1989] | 29 | IMPLICIT NONE |
---|
| 30 | |
---|
[5294] | 31 | !!#include "clesphys.h" |
---|
[2027] | 32 | |
---|
[1989] | 33 | !-- Input arguments |
---|
| 34 | |
---|
| 35 | INTEGER(KIND=JPIM),INTENT(IN) :: KLON |
---|
| 36 | INTEGER(KIND=JPIM) :: KLEV! UNDETERMINED INTENT |
---|
| 37 | INTEGER(KIND=JPIM) :: KSW! UNDETERMINED INTENT |
---|
| 38 | INTEGER(KIND=JPIM),INTENT(IN) :: KIDIA |
---|
| 39 | INTEGER(KIND=JPIM),INTENT(IN) :: KFDIA |
---|
| 40 | INTEGER(KIND=JPIM),INTENT(IN) :: KOVLP |
---|
| 41 | REAL(KIND=JPRB) ,INTENT(IN) :: PAER(KLON,6,KLEV) ! top to bottom |
---|
| 42 | REAL(KIND=JPRB) ,INTENT(IN) :: PALBD(KLON,KSW) |
---|
| 43 | REAL(KIND=JPRB) ,INTENT(IN) :: PALBP(KLON,KSW) |
---|
| 44 | REAL(KIND=JPRB) ,INTENT(IN) :: PAPH(KLON,KLEV+1) |
---|
| 45 | REAL(KIND=JPRB) ,INTENT(IN) :: PAP(KLON,KLEV) |
---|
| 46 | REAL(KIND=JPRB) ,INTENT(IN) :: PTS(KLON) |
---|
| 47 | REAL(KIND=JPRB) ,INTENT(IN) :: PTH(KLON,KLEV+1) |
---|
| 48 | REAL(KIND=JPRB) ,INTENT(IN) :: PT(KLON,KLEV) |
---|
| 49 | REAL(KIND=JPRB) ,INTENT(IN) :: PQ(KLON,KLEV) |
---|
| 50 | REAL(KIND=JPRB) ,INTENT(IN) :: PCCO2 |
---|
| 51 | REAL(KIND=JPRB) ,INTENT(IN) :: POZN(KLON,KLEV) |
---|
| 52 | REAL(KIND=JPRB) ,INTENT(IN) :: PRMU0(KLON) |
---|
| 53 | REAL(KIND=JPRB) ,INTENT(IN) :: PFRCL(KLON,KLEV) ! bottom to top |
---|
| 54 | REAL(KIND=JPRB) ,INTENT(IN) :: PTAUC(KLON,KSW,KLEV) ! bottom to top |
---|
| 55 | REAL(KIND=JPRB) ,INTENT(IN) :: PASYC(KLON,KSW,KLEV) ! bottom to top |
---|
| 56 | REAL(KIND=JPRB) ,INTENT(IN) :: POMGC(KLON,KSW,KLEV) ! bottom to top |
---|
| 57 | REAL(KIND=JPRB) :: PALBT(KLON,KSW) ! Argument NOT used |
---|
| 58 | REAL(KIND=JPRB) ,INTENT(OUT) :: PFSUX(KLON,2,KLEV+1) |
---|
| 59 | REAL(KIND=JPRB) ,INTENT(OUT) :: PFSUC(KLON,2,KLEV+1) |
---|
| 60 | !INTEGER_M :: KMOL, KCLDATM, KNFLAG, KCEFLAG, KIQFLAG, KSTR |
---|
| 61 | |
---|
| 62 | !-- Output arguments |
---|
| 63 | |
---|
| 64 | !----------------------------------------------------------------------- |
---|
| 65 | |
---|
| 66 | !-- dummy integers |
---|
| 67 | |
---|
| 68 | INTEGER(KIND=JPIM) :: ICLDATM, INFLAG, ICEFLAG, I_LIQFLAG, I_NMOL, I_NSTR |
---|
| 69 | |
---|
| 70 | INTEGER(KIND=JPIM) :: IK, IMOL, J1, J2, JAE, JL, JK, JSW |
---|
| 71 | |
---|
| 72 | !-- dummy reals |
---|
| 73 | |
---|
| 74 | REAL(KIND=JPRB) :: Z_PZ(0:JPLAY) , Z_TZ(0:JPLAY) , Z_PAVEL(JPLAY) , Z_TAVEL(JPLAY) |
---|
| 75 | REAL(KIND=JPRB) :: Z_COLDRY(JPLAY) , Z_COLMOL(JPLAY) , Z_WKL(35,JPLAY) |
---|
| 76 | REAL(KIND=JPRB) :: Z_CO2MULT(JPLAY), Z_COLCH4(JPLAY) , Z_COLCO2(JPLAY) , Z_COLH2O(JPLAY) |
---|
| 77 | REAL(KIND=JPRB) :: Z_COLN2O(JPLAY) , Z_COLO2(JPLAY) , Z_COLO3(JPLAY) |
---|
| 78 | REAL(KIND=JPRB) :: Z_FORFAC(JPLAY) , Z_FORFRAC(JPLAY), Z_SELFFAC(JPLAY), Z_SELFFRAC(JPLAY) |
---|
| 79 | REAL(KIND=JPRB) :: Z_FAC00(JPLAY) , Z_FAC01(JPLAY) , Z_FAC10(JPLAY) , Z_FAC11(JPLAY) |
---|
| 80 | REAL(KIND=JPRB) :: Z_TBOUND , Z_ONEMINUS , ZRMU0 , ZADJI0 |
---|
| 81 | REAL(KIND=JPRB) :: ZALBD(KSW) , ZALBP(KSW) , ZFRCL(JPLAY) |
---|
| 82 | REAL(KIND=JPRB) :: ZTAUC(JPLAY,KSW), ZASYC(JPLAY,KSW), ZOMGC(JPLAY,KSW) |
---|
| 83 | REAL(KIND=JPRB) :: ZTAUA(JPLAY,KSW), ZASYA(JPLAY,KSW), ZOMGA(JPLAY,KSW) |
---|
| 84 | |
---|
| 85 | REAL(KIND=JPRB) :: ZBBCD(JPLAY+1), ZBBCU(JPLAY+1), ZBBFD(JPLAY+1), ZBBFU(JPLAY+1) |
---|
| 86 | REAL(KIND=JPRB) :: ZUVCD(JPLAY+1), ZUVCU(JPLAY+1), ZUVFD(JPLAY+1), ZUVFU(JPLAY+1) |
---|
| 87 | REAL(KIND=JPRB) :: ZVSCD(JPLAY+1), ZVSCU(JPLAY+1), ZVSFD(JPLAY+1), ZVSFU(JPLAY+1) |
---|
| 88 | REAL(KIND=JPRB) :: ZNICD(JPLAY+1), ZNICU(JPLAY+1), ZNIFD(JPLAY+1), ZNIFU(JPLAY+1) |
---|
| 89 | |
---|
| 90 | INTEGER(KIND=JPIM) :: I_LAYTROP, I_LAYSWTCH, I_LAYLOW |
---|
| 91 | INTEGER(KIND=JPIM) :: INDFOR(JPLAY), INDSELF(JPLAY) |
---|
| 92 | INTEGER(KIND=JPIM) :: JP(JPLAY), JT(JPLAY), JT1(JPLAY) |
---|
| 93 | |
---|
| 94 | REAL(KIND=JPRB) :: Z_AMD ! Effective molecular weight of dry air (g/mol) |
---|
| 95 | REAL(KIND=JPRB) :: Z_AMW ! Molecular weight of water vapor (g/mol) |
---|
| 96 | REAL(KIND=JPRB) :: Z_AMCO2 ! Molecular weight of carbon dioxide (g/mol) |
---|
| 97 | REAL(KIND=JPRB) :: Z_AMO ! Molecular weight of ozone (g/mol) |
---|
| 98 | REAL(KIND=JPRB) :: Z_AMCH4 ! Molecular weight of methane (g/mol) |
---|
| 99 | REAL(KIND=JPRB) :: Z_AMN2O ! Molecular weight of nitrous oxide (g/mol) |
---|
| 100 | REAL(KIND=JPRB) :: Z_AMC11 ! Molecular weight of CFC11 (g/mol) - CFCL3 |
---|
| 101 | REAL(KIND=JPRB) :: Z_AMC12 ! Molecular weight of CFC12 (g/mol) - CF2CL2 |
---|
| 102 | REAL(KIND=JPRB) :: Z_AVGDRO ! Avogadro's number (molecules/mole) |
---|
| 103 | REAL(KIND=JPRB) :: Z_GRAVIT ! Gravitational acceleration (cm/sec2) |
---|
| 104 | REAL(KIND=JPRB) :: Z_AMM |
---|
| 105 | |
---|
| 106 | ! Atomic weights for conversion from mass to volume mixing ratios; these |
---|
| 107 | ! are the same values used in ECRT to assure accurate conversion to vmr |
---|
| 108 | data Z_AMD / 28.970_JPRB / |
---|
| 109 | data Z_AMW / 18.0154_JPRB / |
---|
| 110 | data Z_AMCO2 / 44.011_JPRB / |
---|
| 111 | data Z_AMO / 47.9982_JPRB / |
---|
| 112 | data Z_AMCH4 / 16.043_JPRB / |
---|
| 113 | data Z_AMN2O / 44.013_JPRB / |
---|
| 114 | data Z_AMC11 / 137.3686_JPRB / |
---|
| 115 | data Z_AMC12 / 120.9140_JPRB / |
---|
| 116 | data Z_AVGDRO/ 6.02214E23_JPRB / |
---|
| 117 | data Z_GRAVIT/ 9.80665E02_JPRB / |
---|
| 118 | |
---|
| 119 | REAL(KIND=JPRB) :: ZCLEAR, ZCLOUD, ZEPSEC, ZTOTCC |
---|
| 120 | |
---|
| 121 | INTEGER(KIND=JPIM) :: IOVLP |
---|
| 122 | REAL(KIND=JPRB) :: ZHOOK_HANDLE |
---|
| 123 | |
---|
| 124 | |
---|
| 125 | #include "srtm_setcoef.intfb.h" |
---|
| 126 | #include "srtm_spcvrt.intfb.h" |
---|
| 127 | |
---|
| 128 | |
---|
| 129 | !----------------------------------------------------------------------- |
---|
| 130 | !-- calculate information needed ny the radiative transfer routine |
---|
| 131 | |
---|
| 132 | IF (LHOOK) CALL DR_HOOK('SRTM_SRTM_224GP',0,ZHOOK_HANDLE) |
---|
| 133 | ZEPSEC = 1.E-06_JPRB |
---|
| 134 | Z_ONEMINUS=1.0_JPRB - ZEPSEC |
---|
| 135 | ZADJI0 = RII0 / RI0 |
---|
| 136 | !-- overlap: 1=max-ran, 2=maximum, 3=random |
---|
| 137 | IOVLP=3 |
---|
| 138 | |
---|
| 139 | !print *,'Entering srtm_srtm_224gp' |
---|
| 140 | |
---|
| 141 | ICLDATM = 1 |
---|
| 142 | INFLAG = 2 |
---|
| 143 | ICEFLAG = 3 |
---|
| 144 | I_LIQFLAG = 1 |
---|
| 145 | I_NMOL = 6 |
---|
| 146 | I_NSTR = 2 |
---|
| 147 | |
---|
| 148 | DO JL = KIDIA, KFDIA |
---|
| 149 | ZRMU0=PRMU0(JL) |
---|
| 150 | IF (ZRMU0 > 0.0_JPRB) THEN |
---|
| 151 | |
---|
| 152 | !- coefficients related to the cloud optical properties (original RRTM_SW) |
---|
| 153 | |
---|
| 154 | ! print *,'just before SRTM_CLDPROP' |
---|
| 155 | |
---|
| 156 | ! DO JK=1,KLEV |
---|
| 157 | ! CLDFRAC(JK) = PFRCL (JL,JK) |
---|
| 158 | ! CLDDAT1(JK) = PSCLA1(JL,JK) |
---|
| 159 | ! CLDDAT2(JK) = PSCLA2(JL,JK) |
---|
| 160 | ! CLDDAT3(JK) = PSCLA3(JL,JK) |
---|
| 161 | ! CLDDAT4(JK) = PSCLA4(JL,JK) |
---|
| 162 | ! DO JMOM=0,16 |
---|
| 163 | ! CLDDATMOM(JMOM,JK)=PSCLMOM(JL,JMOM,JK) |
---|
| 164 | ! ENDDO |
---|
| 165 | ! print 9101,JK,CLDFRAC(JK),CLDDAT1(JK),CLDDAT2(JK),CLDDAT3(JK)& |
---|
| 166 | ! &,CLDDAT4(JK),(CLDDATMOM(JMOM,JK),JMOM=0,NSTR) |
---|
| 167 | 9101 format(1x,'srtm_srtm_224gp Cld :',I3,f7.4,7E12.5) |
---|
| 168 | ! ENDDO |
---|
| 169 | |
---|
| 170 | ! CALL SRTM_CLDPROP & |
---|
| 171 | ! &( KLEV, ICLDATM, INFLAG, ICEFLAG, LIQFLAG, NSTR & |
---|
| 172 | ! &, CLDFRAC, CLDDAT1, CLDDAT2, CLDDAT3, CLDDAT4, CLDDATMOM & |
---|
| 173 | ! &, TAUCLDORIG, TAUCLOUD, SSACLOUD, XMOM & |
---|
| 174 | ! &) |
---|
| 175 | |
---|
| 176 | !- coefficients for the temperature and pressure dependence of the |
---|
| 177 | ! molecular absorption coefficients |
---|
| 178 | |
---|
| 179 | DO J1=1,35 |
---|
| 180 | DO J2=1,KLEV |
---|
| 181 | Z_WKL(J1,J2)=0.0_JPRB |
---|
| 182 | ENDDO |
---|
| 183 | ENDDO |
---|
| 184 | |
---|
| 185 | Z_TBOUND=PTS(JL) |
---|
| 186 | Z_PZ(0) = paph(JL,klev+1)/100._JPRB |
---|
| 187 | Z_TZ(0) = pth (JL,klev+1) |
---|
| 188 | |
---|
| 189 | ZCLEAR=1.0_JPRB |
---|
| 190 | ZCLOUD=0.0_JPRB |
---|
| 191 | ZTOTCC=0.0_JPRB |
---|
| 192 | DO JK = 1, KLEV |
---|
| 193 | Z_PAVEL(JK) = pap(JL,KLEV-JK+1) /100._JPRB |
---|
| 194 | Z_TAVEL(JK) = pt (JL,KLEV-JK+1) |
---|
| 195 | Z_PZ(JK) = paph(JL,KLEV-JK+1)/100._JPRB |
---|
| 196 | Z_TZ(JK) = pth (JL,KLEV-JK+1) |
---|
| 197 | Z_WKL(1,JK) = pq(JL,KLEV-JK+1) *Z_AMD/Z_AMW |
---|
| 198 | Z_WKL(2,JK) = pcco2 *Z_AMD/Z_AMCO2 |
---|
| 199 | Z_WKL(3,JK) = pozn(JL,KLEV-JK+1)*Z_AMD/Z_AMO |
---|
| 200 | Z_WKL(4,JK) = rn2o *Z_AMD/Z_AMN2O |
---|
| 201 | Z_WKL(6,JK) = rch4 *Z_AMD/Z_AMCH4 |
---|
| 202 | Z_AMM = (1-Z_WKL(1,JK))*Z_AMD + Z_WKL(1,JK)*Z_AMW |
---|
| 203 | Z_COLDRY(JK) = (Z_PZ(JK-1)-Z_PZ(JK))*1.E3_JPRB*Z_AVGDRO/(Z_GRAVIT*Z_AMM*(1+Z_WKL(1,JK))) |
---|
| 204 | ! print 9200,JK,PAVEL(JK),TAVEL(JK),(WKL(JA,JK),JA=1,4),WKL(6,JK),COLDRY(JK) |
---|
| 205 | 9200 format(1x,'SRTM ',I3,2F7.1,6E13.5) |
---|
| 206 | |
---|
| 207 | IF (KOVLP == 1) THEN |
---|
| 208 | ZCLEAR=ZCLEAR*(1.0_JPRB-MAX(PFRCL(JL,JK),ZCLOUD)) & |
---|
| 209 | & /(1.0_JPRB-MIN(ZCLOUD,1.0_JPRB-ZEPSEC)) |
---|
| 210 | ZCLOUD=PFRCL(JL,JK) |
---|
| 211 | ZTOTCC=1.0_JPRB-ZCLEAR |
---|
| 212 | ELSEIF (KOVLP == 2) THEN |
---|
| 213 | ZCLOUD=MAX(ZCLOUD,PFRCL(JL,JK)) |
---|
| 214 | ZCLEAR=1.0_JPRB-ZCLOUD |
---|
| 215 | ZTOTCC=ZCLOUD |
---|
| 216 | ELSEIF (KOVLP == 3) THEN |
---|
| 217 | ZCLEAR=ZCLEAR*(1.0_JPRB-PFRCL(JL,JK)) |
---|
| 218 | ZCLOUD=1.0_JPRB-ZCLEAR |
---|
| 219 | ZTOTCC=ZCLOUD |
---|
| 220 | ENDIF |
---|
| 221 | |
---|
| 222 | ENDDO |
---|
| 223 | |
---|
| 224 | ! print *,'ZTOTCC ZCLEAR : ',ZTOTCC,' ',ZCLEAR |
---|
| 225 | |
---|
| 226 | DO IMOL=1,I_NMOL |
---|
| 227 | DO JK=1,KLEV |
---|
| 228 | Z_WKL(IMOL,JK)=Z_COLDRY(JK)* Z_WKL(IMOL,JK) |
---|
| 229 | ENDDO |
---|
| 230 | ENDDO |
---|
| 231 | |
---|
| 232 | ! IF (ZTOTCC == 0.0_JPRB) THEN |
---|
| 233 | ! DO JK=1,KLEV |
---|
| 234 | ! ZFRCL(JK)=0.0_JPRB |
---|
| 235 | ! ENDDO |
---|
| 236 | ! ELSE |
---|
| 237 | ! DO JK=1,KLEV |
---|
| 238 | ! ZFRCL(JK)=PFRCL(JL,JK)/ZTOTCC |
---|
| 239 | ! ENDDO |
---|
| 240 | ! ENDIF |
---|
| 241 | |
---|
| 242 | ! print *,'just before SRTM_SETCOEF' |
---|
| 243 | |
---|
| 244 | ZFRCL(1:KLEV)=PFRCL(JL,1:KLEV) |
---|
| 245 | ZCLEAR=0._JPRB |
---|
| 246 | ZCLOUD=1._JPRB |
---|
| 247 | |
---|
| 248 | CALL SRTM_SETCOEF & |
---|
| 249 | & ( KLEV , I_NMOL,& |
---|
| 250 | & Z_PAVEL , Z_TAVEL , Z_PZ , Z_TZ , Z_TBOUND,& |
---|
| 251 | & Z_COLDRY , Z_WKL,& |
---|
| 252 | & I_LAYTROP, I_LAYSWTCH, I_LAYLOW,& |
---|
| 253 | & Z_CO2MULT, Z_COLCH4 , Z_COLCO2 , Z_COLH2O , Z_COLMOL , Z_COLN2O , Z_COLO2 , Z_COLO3,& |
---|
| 254 | & Z_FORFAC , Z_FORFRAC , INDFOR , Z_SELFFAC, Z_SELFFRAC, INDSELF,& |
---|
| 255 | & Z_FAC00 , Z_FAC01 , Z_FAC10 , Z_FAC11,& |
---|
| 256 | & JP , JT , JT1 & |
---|
| 257 | & ) |
---|
| 258 | |
---|
| 259 | ! print *,'just after SRTM_SETCOEF' |
---|
| 260 | |
---|
| 261 | !- call the radiation transfer routine |
---|
| 262 | |
---|
| 263 | DO JSW=1,KSW |
---|
| 264 | ZALBD(JSW)=PALBD(JL,JSW) |
---|
| 265 | ZALBP(JSW)=PALBP(JL,JSW) |
---|
| 266 | DO JK=1,KLEV |
---|
| 267 | ZTAUC(JK,JSW) = PTAUC(JL,JSW,JK) |
---|
| 268 | ZASYC(JK,JSW) = PASYC(JL,JSW,JK) |
---|
| 269 | ZOMGC(JK,JSW) = POMGC(JL,JSW,JK) |
---|
| 270 | ! print 9002,JSW,JK,ZFRCL(JK),ZTAUC(JK,JSW),ZASYC(JK,JSW),ZOMGC(JK,JSW) |
---|
| 271 | 9002 format(1x,'srtm_224gp ClOPropECmodel ',2I3,f8.4,3E12.5) |
---|
| 272 | ENDDO |
---|
| 273 | ENDDO |
---|
| 274 | |
---|
| 275 | !- mixing of aerosols |
---|
| 276 | |
---|
| 277 | ! print *,'Aerosol optical properties computations' |
---|
| 278 | ! DO JSW=1,KSW |
---|
| 279 | ! print 9012,JSW,(JAE,RSRTAUA(JSW,JAE),RSRPIZA(JSW,JAE),RSRASYA(JSW,JAE),JAE=1,6) |
---|
| 280 | 9012 format(I3,(/,I3,3E13.5)) |
---|
| 281 | ! ENDDO |
---|
| 282 | |
---|
| 283 | ! DO JK=1,KLEV |
---|
| 284 | ! print 9013,JK,(PAER(JL,JAE,JK),JAE=1,6) |
---|
| 285 | 9013 format(1x,I3,6E12.5) |
---|
| 286 | ! ENDDO |
---|
| 287 | |
---|
| 288 | IF (NAER == 0) THEN |
---|
| 289 | DO JSW=1,KSW |
---|
| 290 | DO JK=1,KLEV |
---|
| 291 | ZTAUA(JK,JSW)= 0.0_JPRB |
---|
| 292 | ZASYA(JK,JSW)= 0.0_JPRB |
---|
| 293 | ZOMGA(JK,JSW)= 1.0_JPRB |
---|
| 294 | ENDDO |
---|
| 295 | ENDDO |
---|
| 296 | ELSE |
---|
| 297 | DO JSW=1,KSW |
---|
| 298 | DO JK=1,KLEV |
---|
| 299 | IK=KLEV+1-JK |
---|
| 300 | ZTAUA(JK,JSW)=0.0_JPRB |
---|
| 301 | ZASYA(JK,JSW)=0.0_JPRB |
---|
| 302 | ZOMGA(JK,JSW)=0.0_JPRB |
---|
| 303 | DO JAE=1,6 |
---|
| 304 | ZTAUA(JK,JSW)=ZTAUA(JK,JSW)+RSRTAUA(JSW,JAE)*PAER(JL,JAE,IK) |
---|
| 305 | ZOMGA(JK,JSW)=ZOMGA(JK,JSW)+RSRTAUA(JSW,JAE)*PAER(JL,JAE,IK) & |
---|
| 306 | & *RSRPIZA(JSW,JAE) |
---|
| 307 | ZASYA(JK,JSW)=ZASYA(JK,JSW)+RSRTAUA(JSW,JAE)*PAER(JL,JAE,IK) & |
---|
| 308 | & *RSRPIZA(JSW,JAE)*RSRASYA(JSW,JAE) |
---|
| 309 | ENDDO |
---|
| 310 | IF (ZOMGA(JK,JSW) /= 0.0_JPRB) THEN |
---|
| 311 | ZASYA(JK,JSW)=ZASYA(JK,JSW)/ZOMGA(JK,JSW) |
---|
| 312 | ENDIF |
---|
| 313 | IF (ZTAUA(JK,JSW) /= 0.0_JPRB) THEN |
---|
| 314 | ZOMGA(JK,JSW)=ZOMGA(JK,JSW)/ZTAUA(JK,JSW) |
---|
| 315 | ENDIF |
---|
| 316 | ! print 9003,JSW,JK,ZTAUA(JK,JSW),ZOMGA(JK,JSW),ZASYA(JK,JSW) |
---|
| 317 | 9003 format(1x,'Aerosols ',2I3,3F10.4) |
---|
| 318 | ENDDO |
---|
| 319 | ENDDO |
---|
| 320 | ENDIF |
---|
| 321 | |
---|
| 322 | DO JK=1,KLEV+1 |
---|
| 323 | ZBBCU(JK)=0.0_JPRB |
---|
| 324 | ZBBCD(JK)=0.0_JPRB |
---|
| 325 | ZBBFU(JK)=0.0_JPRB |
---|
| 326 | ZBBFD(JK)=0.0_JPRB |
---|
| 327 | ZUVCU(JK)=0.0_JPRB |
---|
| 328 | ZUVCD(JK)=0.0_JPRB |
---|
| 329 | ZUVFU(JK)=0.0_JPRB |
---|
| 330 | ZUVFD(JK)=0.0_JPRB |
---|
| 331 | ZVSCU(JK)=0.0_JPRB |
---|
| 332 | ZVSCD(JK)=0.0_JPRB |
---|
| 333 | ZVSFU(JK)=0.0_JPRB |
---|
| 334 | ZVSFD(JK)=0.0_JPRB |
---|
| 335 | ZNICU(JK)=0.0_JPRB |
---|
| 336 | ZNICD(JK)=0.0_JPRB |
---|
| 337 | ZNIFU(JK)=0.0_JPRB |
---|
| 338 | ZNIFD(JK)=0.0_JPRB |
---|
| 339 | ENDDO |
---|
| 340 | |
---|
| 341 | ! print *,'just before calling STRM_SPCVRT for JL=',JL,' and ZRMU0=',ZRMU0 |
---|
| 342 | |
---|
| 343 | CALL SRTM_SPCVRT & |
---|
| 344 | & ( KLEV , I_NMOL , KSW , Z_ONEMINUS,& |
---|
| 345 | & Z_PAVEL , Z_TAVEL , Z_PZ , Z_TZ , Z_TBOUND , ZALBD , ZALBP,& |
---|
| 346 | & ZFRCL , ZTAUC , ZASYC , ZOMGC , ZTAUA , ZASYA , ZOMGA , ZRMU0,& |
---|
| 347 | & Z_COLDRY , Z_WKL,& |
---|
| 348 | & I_LAYTROP, I_LAYSWTCH, I_LAYLOW,& |
---|
| 349 | & Z_CO2MULT, Z_COLCH4 , Z_COLCO2 , Z_COLH2O , Z_COLMOL , Z_COLN2O , Z_COLO2 , Z_COLO3,& |
---|
| 350 | & Z_FORFAC , Z_FORFRAC , INDFOR , Z_SELFFAC, Z_SELFFRAC, INDSELF,& |
---|
| 351 | & Z_FAC00 , Z_FAC01 , Z_FAC10 , Z_FAC11,& |
---|
| 352 | & JP , JT , JT1,& |
---|
| 353 | & ZBBFD , ZBBFU , ZUVFD , ZUVFU , ZVSFD , ZVSFU , ZNIFD , ZNIFU,& |
---|
| 354 | & ZBBCD , ZBBCU , ZUVCD , ZUVCU , ZVSCD , ZVSCU , ZNICD , ZNICU & |
---|
| 355 | & ) |
---|
| 356 | |
---|
| 357 | ! print *,'SRTM_SRTM_224GP before potential scaling' |
---|
| 358 | ! IF (IOVLP == 3) THEN |
---|
| 359 | ! DO JK=1,KLEV+1 |
---|
| 360 | !! print 9004,JK,ZBBCU(JK),ZBBCD(JK),ZBBFU(JK),ZBBFD(JK) |
---|
| 361 | 9004 format(1x,'Clear-sky and total fluxes U & D ',I3,4F10.3) |
---|
| 362 | ! PFSUC(JL,1,JK)=ZBBCU(JK) |
---|
| 363 | ! PFSUC(JL,2,JK)=ZBBCD(JK) |
---|
| 364 | ! PFSUX(JL,1,JK)=ZBBFU(JK) |
---|
| 365 | ! PFSUX(JL,2,JK)=ZBBFD(JK) |
---|
| 366 | ! ENDDO |
---|
| 367 | ! ELSE |
---|
| 368 | ! print *,'SRTM_SRTM_224GP after potential scaling' |
---|
| 369 | DO JK=1,KLEV+1 |
---|
| 370 | PFSUC(JL,1,JK)=ZADJI0 * ZBBCU(JK) |
---|
| 371 | PFSUC(JL,2,JK)=ZADJI0 * ZBBCD(JK) |
---|
| 372 | PFSUX(JL,1,JK)=ZADJI0 * ( (1.0_JPRB-ZCLEAR)*ZBBFU(JK)+ZCLEAR*ZBBCU(JK) ) |
---|
| 373 | PFSUX(JL,2,JK)=ZADJI0 * ( (1.0_JPRB-ZCLEAR)*ZBBFD(JK)+ZCLEAR*ZBBCD(JK) ) |
---|
| 374 | ENDDO |
---|
| 375 | ! ENDIF |
---|
| 376 | |
---|
| 377 | ! DO JK=1,KLEV+1 |
---|
| 378 | ! print 9005,JK,PFSUC(JL,1,JK),PFSUC(JL,2,JK),PFSUX(JL,1,JK),PFSUX(JL,2,JK) |
---|
| 379 | 9005 format(1x,'Clear-sky and total fluxes U & D ',I3,4F10.3) |
---|
| 380 | ! ENDDO |
---|
| 381 | |
---|
| 382 | ELSE |
---|
| 383 | DO JK=1,KLEV+1 |
---|
| 384 | PFSUC(JL,1,JK)=0.0_JPRB |
---|
| 385 | PFSUC(JL,2,JK)=0.0_JPRB |
---|
| 386 | PFSUX(JL,1,JK)=0.0_JPRB |
---|
| 387 | PFSUX(JL,2,JK)=0.0_JPRB |
---|
| 388 | ENDDO |
---|
| 389 | ENDIF |
---|
| 390 | ENDDO |
---|
| 391 | |
---|
| 392 | !PRINT *,'OUT OF SRTM_224GP' |
---|
| 393 | |
---|
| 394 | !----------------------------------------------------------------------- |
---|
| 395 | IF (LHOOK) CALL DR_HOOK('SRTM_SRTM_224GP',1,ZHOOK_HANDLE) |
---|
| 396 | END SUBROUTINE SRTM_SRTM_224GP |
---|
| 397 | |
---|