File indexing completed on 2018-03-02 18:37:43 UTC
view on githubraw file Latest commit add29e06 on 2018-01-31 20:35:05 UTC
b2ea1d2979 Jean*0001 module lscale_cond_mod
0002
0003
0004
0005
0006
0007 use simple_sat_vapor_pres_mod, only: escomp, descomp
0008
0009 use constants_mod, only: HLv,HLs,Cp_air,Grav,rdgas,rvgas
0010 use gcm_params_mod, only: gcm_LEN_MBUF, gcm_SQZ_R, gcm_stdMsgUnit
0011
0012 implicit none
0013 private
0014
0015
0016
0017 public lscale_cond, lscale_cond_init
0018
0019
0020
0021
15388b052e Jean*0022 character(len=128) :: version = '$Id: lscale_cond_mod.F90,v 1.2 2017/08/11 20:48:51 jmc Exp $'
b2ea1d2979 Jean*0023 character(len=128) :: tag = '$Name: $'
0024
0025
0026
0027
0028 real, parameter :: d622 = rdgas/rvgas
0029 real, parameter :: d378 = 1.-d622
0030
0031 logical :: do_init=.true.
0032
0033
0034
0035
0036 real :: hc=1.00
0037 logical :: do_evap=.false.
0038
0039 namelist /lscale_cond_nml/ hc, do_evap
0040
0041
0042
0043
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058
0059 subroutine lscale_cond (tin, qin, pfull, phalf, coldT, &
0060 rain, snow, tdel, qdel, qsat, &
0061 myThid, mask, conv )
0062
0063
0064
0065
0066
0067
0068
0069
0070
0071
0072
0073
0074
0075
0076
0077
0078
0079
0080
0081
0082
0083
0084
0085
0086
0087
0088
0089
0090
0091 real , intent(in) , dimension(:,:,:) :: tin, qin, pfull, phalf
0092 logical , intent(in) , dimension(:,:):: coldT
0093 real , intent(out), dimension(:,:) :: rain,snow
0094 real , intent(out), dimension(:,:,:) :: tdel, qdel, qsat
0095 integer, intent(in) :: myThid
0096 real , intent(in) , dimension(:,:,:), optional :: mask
0097 logical, intent(in) , dimension(:,:,:), optional :: conv
0098
0099
0100
0101 logical,dimension(size(tin,1),size(tin,2),size(tin,3)) :: do_adjust
0102 real,dimension(size(tin,1),size(tin,2),size(tin,3)) :: &
0103 esat, desat, dqsat, pmes, pmass
0104 real,dimension(size(tin,1),size(tin,2)) :: hlcp, precip
0105 integer k, kx
0106
0107
0108
0109
0110
0111
0112
0113 kx=size(tin,3)
0114
0115
0116 WHERE (coldT)
0117 hlcp = HLs/Cp_air
0118 ELSEWHERE
0119 hlcp = HLv/Cp_air
0120 END WHERE
0121
0122
0123
0124 call escomp (tin,esat)
0125 call descomp (tin,desat)
0126
0127 esat(:,:,:)=esat(:,:,:)*hc
0128
0129 where (pfull(:,:,:) > d378*esat(:,:,:))
0130 pmes(:,:,:)=1.0/(pfull(:,:,:)-d378*esat(:,:,:))
0131 qsat(:,:,:)=d622*esat(:,:,:)*pmes(:,:,:)
0132 qsat(:,:,:)=max(0.0,qsat(:,:,:))
0133 dqsat(:,:,:)=d622*pfull(:,:,:)*desat(:,:,:)*pmes(:,:,:)*pmes(:,:,:)
0134 elsewhere
0135 pmes(:,:,:)=0.0
0136 qsat(:,:,:)=0.0
0137 dqsat(:,:,:)=0.0
0138 endwhere
0139
0140
0141
0142 if (present(conv)) then
0143
0144 do_adjust(:,:,:)=(.not.conv(:,:,:) .and. &
0145 (qin(:,:,:) - qsat(:,:,:))*qsat(:,:,:) > 0.0)
0146 else
0147
0148 do_adjust(:,:,:)=( (qin(:,:,:) - qsat(:,:,:))*qsat(:,:,:) > 0.0)
0149 endif
0150
0151 if (present(mask)) then
0152 do_adjust(:,:,:)=do_adjust(:,:,:) .and. (mask(:,:,:) > 0.5)
0153 end if
0154
0155
0156 do k = 1,kx
0157 where (do_adjust(:,:,k))
0158 qdel(:,:,k)=(qsat(:,:,k)-qin(:,:,k))/(1.0+hlcp(:,:)*dqsat(:,:,k))
0159 tdel(:,:,k)=-hlcp(:,:)*qdel(:,:,k)
0160 elsewhere
0161 qdel(:,:,k)=0.0
0162 tdel(:,:,k)=0.0
0163 endwhere
0164 end do
0165
0166
0167
0168 do k=1,kx
0169 pmass(:,:,k)=(phalf(:,:,k+1)-phalf(:,:,k))/Grav
0170 enddo
0171
0172
0173
0174 if (do_evap) then
0175 if (present(mask)) then
0176
0177 call precip_evap (pmass,tin,qin,qsat,dqsat,hlcp,tdel,qdel, &
0178 myThid, mask )
0179 else
0180 call precip_evap (pmass,tin,qin,qsat,dqsat,hlcp,tdel,qdel, &
0181 myThid )
0182 endif
0183 endif
0184
0185
0186
0187 precip(:,:)=0.0
0188 do k=1,kx
0189 precip(:,:)=precip(:,:)-pmass(:,:,k)*qdel(:,:,k)
0190 enddo
0191 precip(:,:)=max(precip(:,:),0.0)
0192
0193
0194 WHERE (coldT)
0195 snow = precip
0196 rain = 0.
0197 ELSEWHERE
0198 rain = precip
0199 snow = 0.
0200 END WHERE
0201
0202
0203
0204 end subroutine lscale_cond
0205
0206
0207
0208
0209
0210 subroutine precip_evap (pmass, tin, qin, qsat, dqsat, hlcp, &
0211 tdel, qdel, myThid, mask )
0212
0213
0214
0215
0216 real, intent(in), dimension(:,:,:) :: pmass, tin, qin, qsat, dqsat
0217 real, intent(in), dimension(:,:) :: hlcp
0218 real, intent(inout), dimension(:,:,:) :: tdel, qdel
0219 integer, intent(in) :: myThid
0220 real, intent(in), dimension(:,:,:), optional :: mask
0221
0222 real, dimension(size(tin,1),size(tin,2)) :: exq, def
0223
0224 integer k
0225
0226 exq(:,:)=0.0
0227
0228 do k=1,size(tin,3)
0229
0230 where (qdel(:,:,k) < 0.0) exq(:,:) = exq(:,:) - &
0231 qdel(:,:,k)*pmass(:,:,k)
0232
0233 if (present(mask)) exq(:,:) = exq(:,:)*mask(:,:,k)
0234
0235
0236
0237 where ( (qdel(:,:,k) >= 0.0) .and. (exq(:,:) > 0.0) )
0238 exq(:,:) = exq(:,:) / pmass(:,:,k)
0239 def(:,:) = (qsat(:,:,k)-qin(:,:,k))/(1.+hlcp(:,:)*dqsat(:,:,k))
0240 def(:,:) = min(max(def(:,:),0.0),exq(:,:))
0241 qdel(:,:,k) = qdel(:,:,k) + def(:,:)
0242 tdel(:,:,k) = tdel(:,:,k) - def(:,:)*hlcp(:,:)
0243 exq(:,:) = (exq(:,:)-def(:,:))*pmass(:,:,k)
0244 endwhere
0245
0246 enddo
0247
0248
0249
0250 end subroutine precip_evap
0251
0252
0253
0254 subroutine lscale_cond_init (myThid)
0255
0256
0257
0258
0259
0260
0261
0262 integer, intent(in) :: myThid
0263
0264
0265
0266
0267 integer :: iUnit
0268 CHARACTER*(gcm_LEN_MBUF) :: msgBuf
0269
0270
0271
0272
0273
0274 CALL BARRIER(myThid)
0275 IF ( myThid.EQ.1 ) THEN
0276
0277 WRITE(msgBuf,'(A)') 'LSCALE_COND_INIT: opening data.atm_gray'
0278 CALL PRINT_MESSAGE( msgBuf, gcm_stdMsgUnit, gcm_SQZ_R, myThid )
0279 CALL OPEN_COPY_DATA_FILE( &
0280 'data.atm_gray', 'LSCALE_COND_INIT', &
0281 iUnit, &
0282 myThid )
0283
0284 READ(UNIT=iUnit,NML=lscale_cond_nml)
0285 WRITE(msgBuf,'(A)') &
0286 'LSCALE_COND_INIT: finished reading data.atm_gray'
0287 CALL PRINT_MESSAGE( msgBuf, gcm_stdMsgUnit, gcm_SQZ_R, myThid )
0288
15388b052e Jean*0289 #ifdef SINGLE_DISK_IO
b2ea1d2979 Jean*0290 CLOSE(iUnit)
15388b052e Jean*0291 #else
0292 CLOSE(iUnit,STATUS='DELETE')
0293 #endif /* SINGLE_DISK_IO */
b2ea1d2979 Jean*0294
0295
0296
0297
0298
0299
0300
0301
0302
0303
0304
0305
0306
0307
0308
0309
0310
0311
0312
0313 do_init=.false.
0314
0315 ENDIF
0316 CALL BARRIER(myThid)
0317
0318 end subroutine lscale_cond_init
0319
0320
0321
0322 end module lscale_cond_mod
0323