Changeset 1122 for trunk/LMDZ.GENERIC
- Timestamp:
- Dec 6, 2013, 1:01:19 AM (11 years ago)
- Location:
- trunk/LMDZ.GENERIC
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.GENERIC/README
r1016 r1122 998 998 - First step for rayleigh with variable species. Now, just need to change optcv. 999 999 - changed some interpolation indices in callcorrk to limit dependency of OLR on the number of layers 1000 1001 == 05/12/2013 == JL 1002 - corrected sugascorrk to work in the two band gray aproximation with -b 1x1 and NGAUSS=2 -
trunk/LMDZ.GENERIC/libf/phystd/sugas_corrk.F90
r961 r1122 50 50 real*8 x, xi(4), yi(4), ans, p 51 51 ! For gray case (JL12) 52 real kappa_IR, kappa_VI, IR_VI_wnlimit, nVI_limit,nIR_limit 52 real kappa_IR, kappa_VI, IR_VI_wnlimit 53 integer nVI_limit,nIR_limit 53 54 54 55 integer ngas, igas, jgas … … 102 103 do igas=1,ngas 103 104 read(111,*) gastype(igas) 104 print*,'Gas ',igas,' is ',gastype(igas) 105 print*,'Gas ',igas,' is ',gastype(igas+ real kappa_IR, kappa_VI, IR_VI_wnlimit 106 ) 105 107 enddo 106 108 … … 276 278 !======================================================================= 277 279 ! Get gaseous k-coefficients and interpolate onto finer pressure grid 280 281 282 ! wavelength used to separate IR from VI in graybody. We will need that anyway 283 IR_VI_wnlimit=3000. 284 write(*,*)"graybody: Visible / Infrared separation set at",10000./IR_VI_wnlimit,"um" 285 286 nVI_limit=0 287 Do nw=1,L_NSPECTV 288 if ((WNOV(nw).gt.IR_VI_wnlimit).and.(L_NSPECTV.gt.1)) then 289 nVI_limit=nw-1 290 exit 291 endif 292 End do 293 nIR_limit=L_NSPECTI 294 Do nw=1,L_NSPECTI 295 if ((WNOI(nw).gt.IR_VI_wnlimit).and.(L_NSPECTI.gt.1)) then 296 nIR_limit=nw-1 297 exit 298 endif 299 End do 278 300 279 301 if (graybody) then … … 291 313 write(*,*)" kappa_IR = ",kappa_IR 292 314 kappa_IR=kappa_IR*1.e4* mugaz * 1.672621e-27 ! conversion from m^2/kg to cm^2/molecule 315 316 write(*,*)"graybody: Visible / Infrared separation set at band: IR=",nIR_limit,", VI=",nVI_limit 293 317 294 ! wavelength used to separate IR from VI 295 IR_VI_wnlimit=3000. 296 write(*,*)"graybody: Visible / Infrared separation set at",10000./IR_VI_wnlimit,"um" 297 298 nVI_limit=L_NSPECTV 299 Do nw=1,L_NSPECTV 300 if (WNOV(nw).gt.IR_VI_wnlimit) then 301 nVI_limit=nw-1 302 exit 303 endif 304 End do 305 nIR_limit=L_NSPECTI 306 Do nw=1,L_NSPECTI 307 if (WNOI(nw).gt.IR_VI_wnlimit) then 308 nIR_limit=nw-1 309 exit 310 endif 311 End do 312 write(*,*)"graybody: Visible / Infrared separation set at band ",nIR_limit,nVI_limit 313 318 Else 319 kappa_VI=1.e-30 320 kappa_IR=1.e-30 314 321 End if 315 322 316 323 ! print*,corrkdir(1:4) 317 324 ! VISIBLE 318 if (callgasvis.and.(.not.TRIM(corrkdir).eq.'null').and.(.not.TRIM(corrkdir).eq.'null_LowTeffStar').and.(.not.graybody)) then 319 file_id='/corrk_data/'//trim(adjustl(banddir))//'/corrk_gcm_VI.dat' 320 file_path=TRIM(datadir)//TRIM(file_id) 325 if (callgasvis) then 326 if ((corrkdir(1:4).eq.'null'))then !(TRIM(corrkdir).eq.'null_LowTeffStar')) then 327 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)=0.0 328 print*,'using no corrk data' 329 print*,'Visible corrk gaseous absorption is set to zero if graybody=F' 330 else 331 file_id='/corrk_data/'//trim(adjustl(banddir))//'/corrk_gcm_VI.dat' 332 file_path=TRIM(datadir)//TRIM(file_id) 333 334 ! check that the file exists 335 inquire(FILE=file_path,EXIST=file_ok) 336 if(.not.file_ok) then 337 write(*,*)'The file ',TRIM(file_path) 338 write(*,*)'was not found by sugas_corrk.F90.' 339 write(*,*)'Are you sure you have absorption data for these bands?' 340 call abort 341 endif 321 342 322 ! check that the file exists 323 inquire(FILE=file_path,EXIST=file_ok) 324 if(.not.file_ok) then 325 write(*,*)'The file ',TRIM(file_path) 326 write(*,*)'was not found by sugas_corrk.F90.' 327 write(*,*)'Are you sure you have absorption data for these bands?' 328 call abort 329 endif 330 331 open(111,file=TRIM(file_path),form='formatted') 332 read(111,*) gasv8 333 close(111) 334 335 else if (callgasvis.and.graybody) then 343 open(111,file=TRIM(file_path),form='formatted') 344 read(111,*) gasv8 345 close(111) 346 end if 347 336 348 if(nVI_limit.eq.0) then 337 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)=kappa_VI 349 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)= & 350 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)+kappa_VI 338 351 else if (nVI_limit.eq.L_NSPECTV) then 339 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)=kappa_IR 352 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)= & 353 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTV,1:L_NGAUSS)+kappa_IR 340 354 else 341 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nVI_limit,1:L_NGAUSS)=kappa_IR 342 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nVI_limit+1:L_NSPECTV,1:L_NGAUSS)=kappa_VI 355 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nVI_limit,1:L_NGAUSS)= & 356 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nVI_limit,1:L_NGAUSS)+kappa_IR 357 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nVI_limit+1:L_NSPECTV,1:L_NGAUSS)= & 358 gasv8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nVI_limit+1:L_NSPECTV,1:L_NGAUSS)+kappa_VI 343 359 end if 344 360 else … … 348 364 349 365 ! INFRA-RED 350 if ((.not.TRIM(corrkdir).eq.'null').and.(.not.TRIM(corrkdir).eq.'null_LowTeffStar').and.(.not.graybody)) then 366 if ((corrkdir(1:4).eq.'null'))then !.or.(TRIM(corrkdir).eq.'null_LowTeffStar')) then 367 print*,'Infrared corrk gaseous absorption is set to zero if graybody=F' 368 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)=0.0 369 else 351 370 file_id='/corrk_data/'//trim(adjustl(banddir))//'/corrk_gcm_IR.dat' 352 371 file_path=TRIM(datadir)//TRIM(file_id) … … 403 422 end do 404 423 405 else if (graybody) then 406 if(nIR_limit.eq.0) then 407 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)=kappa_VI 408 else if (nIR_limit.eq.L_NSPECTI) then 409 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)=kappa_IR 410 else 411 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nIR_limit,1:L_NGAUSS)=kappa_IR 412 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nIR_limit+1:L_NSPECTI,1:L_NGAUSS)=kappa_VI 413 end if 424 endif 425 426 if(nIR_limit.eq.0) then 427 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)= & 428 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)+kappa_VI 429 else if (nIR_limit.eq.L_NSPECTI) then 430 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)= & 431 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)+kappa_IR 414 432 else 415 print*,'Infrared corrk gaseous absorption is set to zero.' 416 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:L_NSPECTI,1:L_NGAUSS)=0.0 417 endif 433 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nIR_limit,1:L_NGAUSS)= & 434 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,1:nIR_limit,1:L_NGAUSS)+kappa_IR 435 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nIR_limit+1:L_NSPECTI,1:L_NGAUSS)= & 436 gasi8(1:L_NTREF,1:L_NPREF,1:L_REFVAR,nIR_limit+1:L_NSPECTI,1:L_NGAUSS)+kappa_VI 437 end if 418 438 419 439
Note: See TracChangeset
for help on using the changeset viewer.