25 SUBROUTINE otlift(SLINDX)
31 use lookup_mod, only: thl, rdth, jtb, qs0, sqs, rdq,itb, ptbl, pl, &
32 rdp, the0, sthe, rdthe, ttbl
33 use ctlblk_mod
, only: jsta, jend, im, spval
34 use params_mod, only: d00,h10e5, capa, elocp, eps, oneps
42 real,
PARAMETER :: d8202=.820231e0 , h5e4=5.e4 , p500=50000.
46 real,
intent(out) :: slindx(im,jsta:jend)
47 REAL :: tvp, esatp, qsatp
48 REAL :: tth, tp, apesp, partmp, thesp, tpsp
49 REAL :: bqs00, sqs00, bqs10, sqs10, bq, sq, tq
50 REAL :: p00, p10, p01, p11, t00, t10, t01, t11
51 REAL :: bthe00, sthe00, bthe10, sthe10, bth, sth
52 REAL :: tqq, qq, qbt, tthbt, tbt, apebt, ppq, pp
54 INTEGER :: i, j, lbtm, ittbk, iq, it, iptbk, ith, ip, iqtb
55 INTEGER :: ittb, iptb, ithtb
71 IF(t(i,j,lbtm)<spval .AND. q(i,j,lbtm)<spval)
THEN
74 apebt = (h10e5/pmid(i,j,lbtm))**capa
77 tth = (tthbt-thl)*rdth
96 bq=(bqs10-bqs00)*tqq+bqs00
97 sq=(sqs10-sqs00)*tqq+sqs00
118 tpsp = p00+(p10-p00)*ppq+(p01-p00)*tqq &
119 +(p00-p10-p01+p11)*ppq*tqq
120 IF(tpsp <= d00) tpsp = h10e5
121 apesp = (h10e5/tpsp)**capa
122 thesp = tthbt*exp(elocp*qbt*apesp/tthbt)
143 bth=(bthe10-bthe00)*qq+bthe00
144 sth=(sthe10-sthe00)*qq+sthe00
145 tth=(thesp-bth)/sth*rdthe
166 partmp=(t00+(t10-t00)*pp+(t01-t00)*qq &
167 +(t00-t10-t01+t11)*pp*qq)
169 partmp=tbt*apebt*d8202
180 qsatp=eps*esatp/(p500-esatp*oneps)
181 tvp=partmp*(1+0.608*qsatp)
182 slindx(i,j)=t500(i,j)-tvp
elemental real function, public fpvsnew(t)
calcape() computes CAPE/CINS and other storm related variables.