Changeset 1715 for trunk/LMDZ.GENERIC/libf
- Timestamp:
- Jun 8, 2017, 1:03:06 AM (8 years ago)
- Location:
- trunk/LMDZ.GENERIC/libf/phystd
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.GENERIC/libf/phystd/callcorrk.F90
r1714 r1715 123 123 REAL*8 taucumi(L_LEVELS,L_NSPECTI,L_NGAUSS) 124 124 125 REAL*8 tauaero(L_LEVELS +1,naerkind)125 REAL*8 tauaero(L_LEVELS,naerkind) 126 126 REAL*8 nfluxtopv,nfluxtopi,nfluxtop,fluxtopvdn 127 127 REAL*8 nfluxoutv_nu(L_NSPECTV) ! Outgoing band-resolved VI flux at TOA (W/m2). … … 189 189 190 190 ! test on allocated necessary because of CLFvarying (two calls to callcorrk in physiq) 191 if(.not.allocated(QXVAER)) allocate(QXVAER(L_LEVELS +1,L_NSPECTV,naerkind))192 if(.not.allocated(QSVAER)) allocate(QSVAER(L_LEVELS +1,L_NSPECTV,naerkind))193 if(.not.allocated(GVAER)) allocate(GVAER(L_LEVELS +1,L_NSPECTV,naerkind))194 if(.not.allocated(QXIAER)) allocate(QXIAER(L_LEVELS +1,L_NSPECTI,naerkind))195 if(.not.allocated(QSIAER)) allocate(QSIAER(L_LEVELS +1,L_NSPECTI,naerkind))196 if(.not.allocated(GIAER)) allocate(GIAER(L_LEVELS +1,L_NSPECTI,naerkind))191 if(.not.allocated(QXVAER)) allocate(QXVAER(L_LEVELS,L_NSPECTV,naerkind)) 192 if(.not.allocated(QSVAER)) allocate(QSVAER(L_LEVELS,L_NSPECTV,naerkind)) 193 if(.not.allocated(GVAER)) allocate(GVAER(L_LEVELS,L_NSPECTV,naerkind)) 194 if(.not.allocated(QXIAER)) allocate(QXIAER(L_LEVELS,L_NSPECTI,naerkind)) 195 if(.not.allocated(QSIAER)) allocate(QSIAER(L_LEVELS,L_NSPECTI,naerkind)) 196 if(.not.allocated(GIAER)) allocate(GIAER(L_LEVELS,L_NSPECTI,naerkind)) 197 197 198 198 !!! ALLOCATED instances are necessary because of CLFvarying (strategy to call callcorrk twice in physiq...) … … 323 323 end do !iaer=1,naerkind. 324 324 325 325 326 ! How much light do we get ? 326 327 do nw=1,L_NSPECTV … … 439 440 ! Test / Correct for freaky s. s. albedo values. 440 441 do iaer=1,naerkind 441 do k=1,L_LEVELS +1442 do k=1,L_LEVELS 442 443 443 444 do nw=1,L_NSPECTV … … 482 483 ! boundary conditions 483 484 tauaero(1,iaer) = tauaero(2,iaer) 484 tauaero(L_LEVELS+1,iaer) = tauaero(L_LEVELS,iaer)485 485 !tauaero(1,iaer) = 0. 486 !tauaero(L_LEVELS+1,iaer) = 0.487 486 488 487 end do ! naerkind … … 574 573 575 574 if(kastprof)then 576 577 if(.not.global1d)then ! garde-fou/safeguard added by MT (to be removed in the future) 578 write(*,*) 'You have to fix mu0, ' 579 write(*,*) 'the cosinus of the solar angle' 580 stop 581 endif 582 575 583 576 ! Initial values equivalent to mugaz. 584 577 DO l=1,nlayer -
trunk/LMDZ.GENERIC/libf/phystd/inifis_mod.F90
r1682 r1715 11 11 use init_print_control_mod, only: init_print_control 12 12 use radinc_h, only: ini_radinc_h, naerkind 13 use radcommon_h, only: ini_radcommon_h14 13 use datafile_mod, only: datadir 15 14 use comdiurn_h, only: sinlat, coslat, sinlon, coslon … … 762 761 call ini_radinc_h(nlayer) 763 762 764 ! allocate "radcommon_h" arrays765 call ini_radcommon_h()766 767 763 ! allocate "comsoil_h" arrays 768 764 call ini_comsoil_h(ngrid) -
trunk/LMDZ.GENERIC/libf/phystd/optci.F90
r1397 r1715 32 32 33 33 real*8 DTAUI(L_NLAYRAD,L_NSPECTI,L_NGAUSS) 34 real*8 DTAUKI(L_LEVELS +1,L_NSPECTI,L_NGAUSS)34 real*8 DTAUKI(L_LEVELS,L_NSPECTI,L_NGAUSS) 35 35 real*8 TAUI(L_NLEVRAD,L_NSPECTI,L_NGAUSS) 36 36 real*8 TAUCUMI(L_LEVELS,L_NSPECTI,L_NGAUSS) … … 42 42 43 43 ! for aerosols 44 real*8 QXIAER(L_LEVELS +1,L_NSPECTI,NAERKIND)45 real*8 QSIAER(L_LEVELS +1,L_NSPECTI,NAERKIND)46 real*8 GIAER(L_LEVELS +1,L_NSPECTI,NAERKIND)47 real*8 TAUAERO(L_LEVELS +1,NAERKIND)48 real*8 TAUAEROLK(L_LEVELS +1,L_NSPECTI,NAERKIND)44 real*8 QXIAER(L_LEVELS,L_NSPECTI,NAERKIND) 45 real*8 QSIAER(L_LEVELS,L_NSPECTI,NAERKIND) 46 real*8 GIAER(L_LEVELS,L_NSPECTI,NAERKIND) 47 real*8 TAUAERO(L_LEVELS,NAERKIND) 48 real*8 TAUAEROLK(L_LEVELS,L_NSPECTI,NAERKIND) 49 49 real*8 TAEROS(L_LEVELS,L_NSPECTI,NAERKIND) 50 50 … … 135 135 end do ! levels 136 136 137 137 ! Spectral dependance of aerosol absorption 138 138 do iaer=1,naerkind 139 139 DO NW=1,L_NSPECTI … … 147 147 148 148 do K=2,L_LEVELS 149 150 ! continuum absorption 151 DCONT = 0.0d0 149 150 DAERO=SUM(TAEROS(K,NW,1:naerkind)) ! aerosol absorption 151 152 DCONT = 0.0d0 ! continuum absorption 152 153 153 154 if(continuum.and.(.not.graybody))then … … 225 226 endif 226 227 227 ! aerosol absorption228 DAERO=SUM(TAEROS(K,NW,1:naerkind))229 230 228 do ng=1,L_NGAUSS-1 231 229 … … 286 284 end do 287 285 288 DTAUKI(L_LEVELS+1,1:L_NSPECTI,1:L_NGAUSS)=0.d0289 286 !======================================================================= 290 287 ! Now the full treatment for the layers, where besides the opacity … … 293 290 do iaer=1,naerkind 294 291 DO NW=1,L_NSPECTI 295 DO K=2,L_LEVELS +1296 TAUAEROLK(K,NW,IAER) = TAUAERO(K,IAER)*QSIAER(K,NW,IAER) 292 DO K=2,L_LEVELS 293 TAUAEROLK(K,NW,IAER) = TAUAERO(K,IAER)*QSIAER(K,NW,IAER) ! effect of scattering albedo 297 294 ENDDO 298 295 ENDDO … … 300 297 301 298 DO NW=1,L_NSPECTI 302 DO L=1,L_NLAYRAD 299 DO L=1,L_NLAYRAD-1 303 300 K = 2*L+1 304 301 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) 305 302 END DO ! L vertical loop 303 304 ! Last level 305 L = L_NLAYRAD 306 K = 2*L+1 307 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) 308 306 309 END DO ! NW spectral loop 307 310 … … 309 312 DO NW=1,L_NSPECTI 310 313 NG = L_NGAUSS 311 DO L=1,L_NLAYRAD 314 DO L=1,L_NLAYRAD-1 312 315 313 316 K = 2*L+1 … … 334 337 335 338 END DO ! L vertical loop 339 340 ! Last level 341 342 L = L_NLAYRAD 343 K = 2*L+1 344 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG) ! + 1.e-50 345 346 atemp = 0. 347 if(DTAUI(L,NW,NG) .GT. 1.0D-9) then 348 do iaer=1,naerkind 349 atemp = atemp + GIAER(K,NW,IAER) * TAUAEROLK(K,NW,IAER) 350 end do 351 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 352 else 353 WBARI(L,nw,ng) = 0.0D0 354 DTAUI(L,NW,NG) = 1.0D-9 355 endif 356 357 if(btemp(L,nw) .GT. 0.0d0) then 358 cosbi(L,NW,NG) = atemp/btemp(L,nw) 359 else 360 cosbi(L,NW,NG) = 0.0D0 361 end if 362 336 363 337 364 ! Now the other Gauss points, if needed. … … 340 367 IF(TAUGSURF(NW,NG) .gt. TLIMIT) THEN 341 368 342 DO L=1,L_NLAYRAD 369 DO L=1,L_NLAYRAD-1 343 370 K = 2*L+1 344 371 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG)+DTAUKI(K+1,NW,NG)! + 1.e-50 … … 355 382 cosbi(L,NW,NG) = cosbi(L,NW,L_NGAUSS) 356 383 END DO ! L vertical loop 384 385 ! Last level 386 L = L_NLAYRAD 387 K = 2*L+1 388 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG)! + 1.e-50 389 390 if(DTAUI(L,NW,NG) .GT. 1.0D-9) then 391 392 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 393 394 else 395 WBARI(L,nw,ng) = 0.0D0 396 DTAUI(L,NW,NG) = 1.0D-9 397 endif 398 399 cosbi(L,NW,NG) = cosbi(L,NW,L_NGAUSS) 400 357 401 END IF 358 402 -
trunk/LMDZ.GENERIC/libf/phystd/optcv.F90
r1397 r1715 24 24 ! 25 25 ! THIS SUBROUTINE SETS THE OPTICAL CONSTANTS IN THE VISUAL 26 ! IT CALCU ALTES FOR EACH LAYER, FOR EACH SPECRAL INTERVAL IN THE VISUAL26 ! IT CALCULATES FOR EACH LAYER, FOR EACH SPECTRAL INTERVAL IN THE VISUAL 27 27 ! LAYER: WBAR, DTAU, COSBAR 28 28 ! LEVEL: TAU … … 39 39 40 40 real*8 DTAUV(L_NLAYRAD,L_NSPECTV,L_NGAUSS) 41 real*8 DTAUKV(L_LEVELS +1,L_NSPECTV,L_NGAUSS)41 real*8 DTAUKV(L_LEVELS,L_NSPECTV,L_NGAUSS) 42 42 real*8 TAUV(L_NLEVRAD,L_NSPECTV,L_NGAUSS) 43 43 real*8 TAUCUMV(L_LEVELS,L_NSPECTV,L_NGAUSS) … … 48 48 49 49 ! for aerosols 50 real*8 QXVAER(L_LEVELS +1,L_NSPECTV,NAERKIND)51 real*8 QSVAER(L_LEVELS +1,L_NSPECTV,NAERKIND)52 real*8 GVAER(L_LEVELS +1,L_NSPECTV,NAERKIND)53 real*8 TAUAERO(L_LEVELS +1,NAERKIND)54 real*8 TAUAEROLK(L_LEVELS +1,L_NSPECTV,NAERKIND)50 real*8 QXVAER(L_LEVELS,L_NSPECTV,NAERKIND) 51 real*8 QSVAER(L_LEVELS,L_NSPECTV,NAERKIND) 52 real*8 GVAER(L_LEVELS,L_NSPECTV,NAERKIND) 53 real*8 TAUAERO(L_LEVELS,NAERKIND) 54 real*8 TAUAEROLK(L_LEVELS,L_NSPECTV,NAERKIND) 55 55 real*8 TAEROS(L_LEVELS,L_NSPECTV,NAERKIND) 56 56 … … 60 60 real*8 TAURAY(L_NSPECTV) 61 61 real*8 TRAY(L_LEVELS,L_NSPECTV) 62 real*8 TRAYAER63 62 real*8 DPR(L_LEVELS), U(L_LEVELS) 64 63 real*8 LCOEF(4), LKCOEF(L_LEVELS,4) … … 66 65 real*8 taugsurf(L_NSPECTV,L_NGAUSS-1) 67 66 real*8 DCONT,DAERO 67 real*8 DRAYAER 68 68 double precision wn_cont, p_cont, p_air, T_cont, dtemp, dtempc 69 69 double precision p_cross … … 123 123 end do ! levels 124 124 125 125 ! Spectral dependance of aerosol absorption 126 126 do iaer=1,naerkind 127 127 do NW=1,L_NSPECTV … … 131 131 end do 132 132 end do 133 134 ! Rayleigh scattering 133 135 do NW=1,L_NSPECTV 134 136 do K=2,L_LEVELS … … 142 144 do NW=1,L_NSPECTV 143 145 144 TRAYAER = TRAY(K,NW)145 ! TRAYAER is Tau RAYleigh scattering, plus AERosol opacity146 DRAYAER = TRAY(K,NW) 147 ! DRAYAER is Tau RAYleigh scattering, plus AERosol opacity 146 148 do iaer=1,naerkind 147 TRAYAER = TRAYAER + TAEROS(K,NW,IAER)149 DRAYAER = DRAYAER + TAEROS(K,NW,IAER) 148 150 end do 149 151 … … 257 259 TAUGSURF(NW,NG) = TAUGSURF(NW,NG) + TAUGAS + DCONT 258 260 DTAUKV(K,nw,ng) = TAUGAS & 259 + TRAYAER & ! TRAYAER includes all scattering contributions261 + DRAYAER & ! DRAYAER includes all scattering contributions 260 262 + DCONT ! For parameterized continuum aborption 261 263 … … 266 268 267 269 NG = L_NGAUSS 268 DTAUKV(K,nw,ng) = TRAY(K,NW) + DCONT ! Forparameterized continuum absorption269 270 do iaer=1,naerkind271 DTAUKV(K,nw,ng) = DTAUKV(K,nw,ng) + TAEROS(K,NW,IAER)272 end do ! a bug was here!270 DTAUKV(K,nw,ng) = DRAYAER + DCONT ! Scattering + parameterized continuum absorption 271 272 ! do iaer=1,naerkind 273 ! DTAUKV(K,nw,ng) = DTAUKV(K,nw,ng) + TAEROS(K,NW,IAER) 274 ! end do ! a bug was here! 273 275 274 276 end do … … 282 284 do iaer=1,naerkind 283 285 DO NW=1,L_NSPECTV 284 DO K=2,L_LEVELS ! AS: shouldn't this be L_LEVELS+1 ? (see optci)285 TAUAEROLK(K,NW,IAER) = TAUAERO(K,IAER) * QSVAER(K,NW,IAER) 286 DO K=2,L_LEVELS 287 TAUAEROLK(K,NW,IAER) = TAUAERO(K,IAER) * QSVAER(K,NW,IAER) ! effect of scattering albedo 286 288 ENDDO 287 289 ENDDO … … 293 295 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind))+SUM(GVAER(K+1,NW,1:naerkind) * TAUAEROLK(K+1,NW,1:naerkind)) 294 296 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) 295 ctemp(L,NW) = btemp(L,NW) + 0.9999*(TRAY(K,NW) + TRAY(K+1,NW)) 297 ctemp(L,NW) = btemp(L,NW) + 0.9999*(TRAY(K,NW) + TRAY(K+1,NW)) ! JVO 2017 : does this 0.999 is really meaningful ? 296 298 btemp(L,NW) = btemp(L,NW) + TRAY(K,NW) + TRAY(K+1,NW) 297 299 COSBV(L,NW,1:L_NGAUSS) = atemp(L,NW)/btemp(L,NW) 298 300 END DO ! L vertical loop 299 301 300 ! last level301 L 302 K 303 atemp(L,NW) 302 ! Last level 303 L = L_NLAYRAD 304 K = 2*L+1 305 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind)) 304 306 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) 305 ctemp(L,NW) = btemp(L,NW) + 0.9999*TRAY(K,NW) 307 ctemp(L,NW) = btemp(L,NW) + 0.9999*TRAY(K,NW) ! JVO 2017 : does this 0.999 is really meaningful ? 306 308 btemp(L,NW) = btemp(L,NW) + TRAY(K,NW) 307 309 COSBV(L,NW,1:L_NGAUSS) = atemp(L,NW)/btemp(L,NW) … … 320 322 END DO ! L vertical loop 321 323 322 ! No vertical averaging on bottom layer324 ! Last level 323 325 324 326 L = L_NLAYRAD -
trunk/LMDZ.GENERIC/libf/phystd/radcommon_h.F90
r1529 r1715 126 126 127 127 real*8,save :: PTOP 128 real*8,save,allocatable :: TAUREF(:)129 128 130 129 real*8,parameter :: UBARI = 0.5D0 … … 132 131 real*8,save :: gweight(L_NGAUSS) 133 132 !$OMP THREADPRIVATE(QREFvis,QREFir,omegaREFvis,omegaREFir,& ! gweight read by master in sugas_corrk 134 !$OMP tstellar,planckir,PTOP ,TAUREF)133 !$OMP tstellar,planckir,PTOP) 135 134 136 135 ! If the gas optical depth (top to the surface) is less than … … 156 155 !$OMP THREADPRIVATE(glat,eclipse) 157 156 158 contains159 160 subroutine ini_radcommon_h161 use radinc_h, only: L_LEVELS162 implicit none163 164 allocate(TAUREF(L_LEVELS+1))165 166 end subroutine ini_radcommon_h167 168 157 end module radcommon_h
Note: See TracChangeset
for help on using the changeset viewer.