Changeset 24 for trunk/src/verttransform_nests.f90
- Timestamp:
- May 23, 2014, 11:48:41 AM (10 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/verttransform_nests.f90
r4 r24 21 21 22 22 subroutine verttransform_nests(n,uuhn,vvhn,wwhn,pvhn) 23 ! 23 ! i i i i i 24 24 !***************************************************************************** 25 25 ! * … … 72 72 integer :: rain_cloud_above,kz_inv 73 73 real :: f_qvsat,pressure,rh,lsp,convp 74 real :: uvzlev(nuvzmax),wzlev(nwzmax),rhoh(nuvzmax),pinmconv(nzmax)74 real :: wzlev(nwzmax),rhoh(nuvzmax),pinmconv(nzmax) 75 75 real :: uvwzlev(0:nxmaxn-1,0:nymaxn-1,nzmax) 76 real :: ew,pint,tv,tvold,pold,dz1,dz2,dz,ui,vi 76 real :: ew,pint,tv,tvold,pold,dz1,dz2,dz,ui,vi,cosf 77 77 real :: dzdx,dzdy 78 78 real :: dzdx1,dzdx2,dzdy1,dzdy2 … … 96 96 97 97 tvold=tt2n(ix,jy,1,n,l)*(1.+0.378*ew(td2n(ix,jy,1,n,l))/ & 98 98 psn(ix,jy,1,n,l)) 99 99 pold=psn(ix,jy,1,n,l) 100 uv zlev(1)=0.100 uvwzlev(ix,jy,1)=0. 101 101 wzlev(1)=0. 102 102 rhoh(1)=pold/(r_air*tvold) … … 112 112 113 113 if (abs(tv-tvold).gt.0.2) then 114 uv zlev(kz)=uvzlev(kz-1)+const*log(pold/pint)* &115 114 uvwzlev(ix,jy,kz)=uvwzlev(ix,jy,kz-1)+const*log(pold/pint)* & 115 (tv-tvold)/log(tv/tvold) 116 116 else 117 uv zlev(kz)=uvzlev(kz-1)+const*log(pold/pint)*tv117 uvwzlev(ix,jy,kz)=uvwzlev(ix,jy,kz-1)+const*log(pold/pint)*tv 118 118 endif 119 119 … … 124 124 125 125 do kz=2,nwz-1 126 wzlev(kz)=(uvzlev(kz+1)+uvzlev(kz))/2. 127 end do 128 wzlev(nwz)=wzlev(nwz-1)+ & 129 uvzlev(nuvz)-uvzlev(nuvz-1) 130 131 ! NOTE: In FLEXPART versions up to 4.0, the number of model levels was doubled 132 ! upon the transformation to z levels. In order to save computer memory, this is 133 ! not done anymore in the standard version. However, this option can still be 134 ! switched on by replacing the following lines with those below, that are 135 ! currently commented out. 136 ! Note that one change is also necessary in gridcheck.f, 137 ! and three changes in verttransform.f 138 !***************************************************************************** 139 uvwzlev(ix,jy,1)=0.0 140 do kz=2,nuvz 141 uvwzlev(ix,jy,kz)=uvzlev(kz) 142 end do 143 144 ! Switch on following lines to use doubled vertical resolution 145 ! Switch off the three lines above. 146 !************************************************************* 147 !22 uvwzlev(ix,jy,(kz-1)*2)=uvzlev(kz) 148 ! do 23 kz=2,nwz 149 !23 uvwzlev(ix,jy,(kz-1)*2+1)=wzlev(kz) 150 ! End doubled vertical resolution 126 wzlev(kz)=(uvwzlev(ix,jy,kz+1)+uvwzlev(ix,jy,kz))/2. 127 end do 128 wzlev(nwz)=wzlev(nwz-1)+uvwzlev(ix,jy,nuvz)-uvwzlev(ix,jy,nuvz-1) 151 129 152 130 ! pinmconv=(h2-h1)/(p2-p1) 153 131 154 132 pinmconv(1)=(uvwzlev(ix,jy,2)-uvwzlev(ix,jy,1))/ & 155 156 133 ((aknew(2)+bknew(2)*psn(ix,jy,1,n,l))- & 134 (aknew(1)+bknew(1)*psn(ix,jy,1,n,l))) 157 135 do kz=2,nz-1 158 136 pinmconv(kz)=(uvwzlev(ix,jy,kz+1)-uvwzlev(ix,jy,kz-1))/ & 159 160 137 ((aknew(kz+1)+bknew(kz+1)*psn(ix,jy,1,n,l))- & 138 (aknew(kz-1)+bknew(kz-1)*psn(ix,jy,1,n,l))) 161 139 end do 162 140 pinmconv(nz)=(uvwzlev(ix,jy,nz)-uvwzlev(ix,jy,nz-1))/ & 163 164 141 ((aknew(nz)+bknew(nz)*psn(ix,jy,1,n,l))- & 142 (aknew(nz-1)+bknew(nz-1)*psn(ix,jy,1,n,l))) 165 143 166 144 … … 183 161 do iz=2,nz-1 184 162 do kz=kmin,nuvz 185 if(height(iz).gt.uv zlev(nuvz)) then163 if(height(iz).gt.uvwzlev(ix,jy,nuvz)) then 186 164 uun(ix,jy,iz,n,l)=uun(ix,jy,nz,n,l) 187 165 vvn(ix,jy,iz,n,l)=vvn(ix,jy,nz,n,l) … … 192 170 goto 30 193 171 endif 194 if ((height(iz).gt.uv zlev(kz-1)).and. &195 (height(iz).le.uvzlev(kz))) then196 dz1=height(iz)-uv zlev(kz-1)197 dz2=uv zlev(kz)-height(iz)172 if ((height(iz).gt.uvwzlev(ix,jy,kz-1)).and. & 173 (height(iz).le.uvwzlev(ix,jy,kz))) then 174 dz1=height(iz)-uvwzlev(ix,jy,kz-1) 175 dz2=uvwzlev(ix,jy,kz)-height(iz) 198 176 dz=dz1+dz2 199 177 uun(ix,jy,iz,n,l)=(uuhn(ix,jy,kz-1,l)*dz2+ & 200 178 uuhn(ix,jy,kz,l)*dz1)/dz 201 179 vvn(ix,jy,iz,n,l)=(vvhn(ix,jy,kz-1,l)*dz2+ & 202 180 vvhn(ix,jy,kz,l)*dz1)/dz 203 181 ttn(ix,jy,iz,n,l)=(tthn(ix,jy,kz-1,n,l)*dz2+ & 204 182 tthn(ix,jy,kz,n,l)*dz1)/dz 205 183 qvn(ix,jy,iz,n,l)=(qvhn(ix,jy,kz-1,n,l)*dz2+ & 206 184 qvhn(ix,jy,kz,n,l)*dz1)/dz 207 185 pvn(ix,jy,iz,n,l)=(pvhn(ix,jy,kz-1,l)*dz2+ & 208 186 pvhn(ix,jy,kz,l)*dz1)/dz 209 187 rhon(ix,jy,iz,n,l)=(rhoh(kz-1)*dz2+rhoh(kz)*dz1)/dz 210 188 kmin=kz … … 225 203 do kz=kmin,nwz 226 204 if ((height(iz).gt.wzlev(kz-1)).and. & 227 228 dz1=height(iz)-wzlev(kz-1)229 dz2=wzlev(kz)-height(iz)230 dz=dz1+dz2231 wwn(ix,jy,iz,n,l)=(wwhn(ix,jy,kz-1,l)*pinmconv(kz-1)*dz2 &232 233 kmin=kz234 goto 40205 (height(iz).le.wzlev(kz))) then 206 dz1=height(iz)-wzlev(kz-1) 207 dz2=wzlev(kz)-height(iz) 208 dz=dz1+dz2 209 wwn(ix,jy,iz,n,l)=(wwhn(ix,jy,kz-1,l)*pinmconv(kz-1)*dz2 & 210 +wwhn(ix,jy,kz,l)*pinmconv(kz)*dz1)/dz 211 kmin=kz 212 goto 40 235 213 endif 236 214 end do … … 242 220 243 221 drhodzn(ix,jy,1,n,l)=(rhon(ix,jy,2,n,l)-rhon(ix,jy,1,n,l))/ & 244 222 (height(2)-height(1)) 245 223 do kz=2,nz-1 246 224 drhodzn(ix,jy,kz,n,l)=(rhon(ix,jy,kz+1,n,l)- & 247 225 rhon(ix,jy,kz-1,n,l))/(height(kz+1)-height(kz-1)) 248 226 end do 249 227 drhodzn(ix,jy,nz,n,l)=drhodzn(ix,jy,nz-1,n,l) … … 259 237 260 238 do jy=1,nyn(l)-2 239 cosf=cos((real(jy)*dyn(l)+ylat0n(l))*pi180) 261 240 do ix=1,nxn(l)-2 262 241 … … 264 243 do iz=2,nz-1 265 244 266 ui=uun(ix,jy,iz,n,l)*dxconst*xresoln(l)/ & 267 cos((real(jy)*dyn(l)+ylat0n(l))*pi180) 245 ui=uun(ix,jy,iz,n,l)*dxconst*xresoln(l)/cosf 268 246 vi=vvn(ix,jy,iz,n,l)*dyconst*yresoln(l) 269 247 … … 319 297 rain_cloud_above=1 320 298 cloudsnh(ix,jy,n,l)=cloudsnh(ix,jy,n,l)+ & 321 299 height(kz)-height(kz-1) 322 300 if (lsp.ge.convp) then 323 301 cloudsn(ix,jy,kz,n,l)=3 ! lsp dominated rainout
Note: See TracChangeset
for help on using the changeset viewer.