Changeset 2157 for palm


Ignore:
Timestamp:
Feb 22, 2017 3:10:35 PM (8 years ago)
Author:
suehring
Message:

Bugfix in read_restart_data.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • palm/trunk/SOURCE/radiation_model_mod.f90

    r2101 r2157  
    2020! Current revisions:
    2121! -----------------
    22 !
     22! Bugfix in read_restart data
    2323!
    2424! Former revisions:
     
    33993399          tmp_3d   !<
    34003400
     3401    REAL(wp),                                                                  &
     3402       DIMENSION(0:0,nys_on_file-nbgp:nyn_on_file+nbgp,nxl_on_file-nbgp:nxr_on_file+nbgp) ::&
     3403          tmp_3d2   !<
     3404
    34013405
    34023406
     
    34373441                CASE ( 'rad_lw_in' )
    34383442                   IF ( .NOT. ALLOCATED( rad_lw_in ) )  THEN
    3439                       ALLOCATE( rad_lw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3443                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3444                           radiation_scheme == 'constant')  THEN
     3445                         ALLOCATE( rad_lw_in(0:0,nysg:nyng,nxlg:nxrg) )
     3446                      ELSE
     3447                         ALLOCATE( rad_lw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3448                      ENDIF
    34403449                   ENDIF 
    3441                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3442                    rad_lw_in(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3450                   IF ( k == 1 )  THEN
     3451                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3452                           radiation_scheme == 'constant')  THEN
     3453                         READ ( 13 )  tmp_2d
     3454                         rad_lw_in(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3455                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3456                      ELSE
     3457                         READ ( 13 )  tmp_3d
     3458                         rad_lw_in(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    34433459                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3460                      ENDIF
     3461                   ENDIF
    34443462
    34453463                CASE ( 'rad_lw_in_av' )
    34463464                   IF ( .NOT. ALLOCATED( rad_lw_in_av ) )  THEN
    3447                       ALLOCATE( rad_lw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3465                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3466                           radiation_scheme == 'constant')  THEN
     3467                         ALLOCATE( rad_lw_in_av(0:0,nysg:nyng,nxlg:nxrg) )
     3468                      ELSE
     3469                         ALLOCATE( rad_lw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3470                      ENDIF
    34483471                   ENDIF 
    3449                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3450                    rad_lw_in_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3472                   IF ( k == 1 )  THEN
     3473                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3474                           radiation_scheme == 'constant')  THEN
     3475                         READ ( 13 )  tmp_2d
     3476                         rad_lw_in_av(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3477                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3478                      ELSE
     3479                         READ ( 13 )  tmp_3d
     3480                         rad_lw_in_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    34513481                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3482                      ENDIF
     3483                   ENDIF
    34523484
    34533485                CASE ( 'rad_lw_out' )
    34543486                   IF ( .NOT. ALLOCATED( rad_lw_out ) )  THEN
    3455                       ALLOCATE( rad_lw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3487                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3488                           radiation_scheme == 'constant')  THEN
     3489                         ALLOCATE( rad_lw_out(0:0,nysg:nyng,nxlg:nxrg) )
     3490                      ELSE
     3491                         ALLOCATE( rad_lw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3492                      ENDIF
    34563493                   ENDIF 
    3457                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3458                    rad_lw_out(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3494                   IF ( k == 1 )  THEN
     3495                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3496                           radiation_scheme == 'constant')  THEN
     3497                         READ ( 13 )  tmp_2d
     3498                         rad_lw_out(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3499                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3500                      ELSE
     3501                         READ ( 13 )  tmp_3d
     3502                         rad_lw_out(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    34593503                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3504                      ENDIF
     3505                   ENDIF
    34603506
    34613507                CASE ( 'rad_lw_out_av' )
    34623508                   IF ( .NOT. ALLOCATED( rad_lw_out_av ) )  THEN
    3463                       ALLOCATE( rad_lw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3509                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3510                           radiation_scheme == 'constant')  THEN
     3511                         ALLOCATE( rad_lw_out_av(0:0,nysg:nyng,nxlg:nxrg) )
     3512                      ELSE
     3513                         ALLOCATE( rad_lw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3514                      ENDIF
    34643515                   ENDIF 
    3465                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3466                    rad_lw_out_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3516                   IF ( k == 1 )  THEN
     3517                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3518                           radiation_scheme == 'constant')  THEN
     3519                         READ ( 13 )  tmp_2d
     3520                         rad_lw_out_av(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3521                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3522                      ELSE
     3523                         READ ( 13 )  tmp_3d
     3524                         rad_lw_out_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    34673525                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3526                      ENDIF
     3527                   ENDIF
    34683528
    34693529                CASE ( 'rad_lw_out_change_0' )
     
    35093569                CASE ( 'rad_sw_in' )
    35103570                   IF ( .NOT. ALLOCATED( rad_sw_in ) )  THEN
    3511                       ALLOCATE( rad_sw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3571                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3572                           radiation_scheme == 'constant')  THEN
     3573                         ALLOCATE( rad_sw_in(0:0,nysg:nyng,nxlg:nxrg) )
     3574                      ELSE
     3575                         ALLOCATE( rad_sw_in(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3576                      ENDIF
    35123577                   ENDIF 
    3513                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3514                    rad_sw_in(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3578                   IF ( k == 1 )  THEN
     3579                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3580                           radiation_scheme == 'constant')  THEN
     3581                         READ ( 13 )  tmp_2d
     3582                         rad_sw_in(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3583                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3584                      ELSE
     3585                         READ ( 13 )  tmp_3d
     3586                         rad_sw_in(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    35153587                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3588                      ENDIF
     3589                   ENDIF
    35163590
    35173591                CASE ( 'rad_sw_in_av' )
    35183592                   IF ( .NOT. ALLOCATED( rad_sw_in_av ) )  THEN
    3519                       ALLOCATE( rad_sw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3593                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3594                           radiation_scheme == 'constant')  THEN
     3595                         ALLOCATE( rad_sw_in_av(0:0,nysg:nyng,nxlg:nxrg) )
     3596                      ELSE
     3597                         ALLOCATE( rad_sw_in_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3598                      ENDIF
    35203599                   ENDIF 
    3521                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3522                    rad_sw_in_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3600                   IF ( k == 1 )  THEN
     3601                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3602                           radiation_scheme == 'constant')  THEN
     3603                         READ ( 13 )  tmp_2d
     3604                         rad_sw_in_av(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3605                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3606                      ELSE
     3607                         READ ( 13 )  tmp_3d
     3608                         rad_sw_in_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    35233609                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3610                      ENDIF
     3611                   ENDIF
    35243612
    35253613                CASE ( 'rad_sw_out' )
    35263614                   IF ( .NOT. ALLOCATED( rad_sw_out ) )  THEN
    3527                       ALLOCATE( rad_sw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3615                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3616                           radiation_scheme == 'constant')  THEN
     3617                         ALLOCATE( rad_sw_out(0:0,nysg:nyng,nxlg:nxrg) )
     3618                      ELSE
     3619                         ALLOCATE( rad_sw_out(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3620                      ENDIF
    35283621                   ENDIF 
    3529                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3530                    rad_sw_out(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3622                   IF ( k == 1 )  THEN
     3623                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3624                           radiation_scheme == 'constant')  THEN
     3625                         READ ( 13 )  tmp_2d
     3626                         rad_sw_out(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3627                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3628                      ELSE
     3629                         READ ( 13 )  tmp_3d
     3630                         rad_sw_out(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    35313631                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3632                      ENDIF
     3633                   ENDIF
    35323634
    35333635                CASE ( 'rad_sw_out_av' )
    35343636                   IF ( .NOT. ALLOCATED( rad_sw_out_av ) )  THEN
    3535                       ALLOCATE( rad_sw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3637                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3638                           radiation_scheme == 'constant')  THEN
     3639                         ALLOCATE( rad_sw_out_av(0:0,nysg:nyng,nxlg:nxrg) )
     3640                      ELSE
     3641                         ALLOCATE( rad_sw_out_av(nzb:nzt+1,nysg:nyng,nxlg:nxrg) )
     3642                      ENDIF
    35363643                   ENDIF 
    3537                    IF ( k == 1 )  READ ( 13 )  tmp_3d
    3538                    rad_sw_out_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) = &
     3644                   IF ( k == 1 )  THEN
     3645                      IF ( radiation_scheme == 'clear-sky'  .OR.               &
     3646                           radiation_scheme == 'constant')  THEN
     3647                         READ ( 13 )  tmp_2d
     3648                         rad_sw_out_av(0:0,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
     3649                             tmp_3d2(0:0,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3650                      ELSE
     3651                         READ ( 13 )  tmp_3d
     3652                         rad_sw_out_av(:,nysc-nbgp:nync+nbgp,nxlc-nbgp:nxrc+nbgp) =&
    35393653                             tmp_3d(:,nysf-nbgp:nynf+nbgp,nxlf-nbgp:nxrf+nbgp)
     3654                      ENDIF
     3655                   ENDIF
    35403656
    35413657                CASE ( 'rad_sw_cs_hr' )
Note: See TracChangeset for help on using the changeset viewer.