Ignore:
Timestamp:
Dec 17, 2025, 7:33:39 PM (6 weeks ago)
Author:
yann meurdesoif
Message:

Separate pbl_surface into 3 subroutines for GPU port

pbl_surface_uncompress_pre : prepare computation for sub subsurface before compressing
pbl_surface_subsrf : each sub-surface is called one after other (horizontal = knon)
pbl_surface_uncompress_post : sub-surface are uncompressed, computation is done on whole domain (horizontal = klon)

pbl_surface_main becomes the driver, calling pbl_surface_uncompress_pre, and then looping under sub-surface (and calling pbl_surface_subsrf) and then calling pbl_surface_uncompress_post.

merge of commit r5868

YM

File:
1 edited

Legend:

Unmodified
Added
Removed
  • LMDZ6/trunk/libf/phylmd/surf_land_bucket_mod.F90

    r5486 r5942  
    5454!****************************************************************************************
    5555    INTEGER, INTENT(IN)                     :: itime, jour, knon
    56     INTEGER, DIMENSION(klon), INTENT(IN)    :: knindex
     56    INTEGER, DIMENSION(knon), INTENT(IN)    :: knindex
    5757    LOGICAL, INTENT(IN)                     :: debut
    5858    REAL, INTENT(IN)                        :: dtime
    59     REAL, DIMENSION(klon), INTENT(IN)       :: tsurf
    60     REAL, DIMENSION(klon), INTENT(IN)       :: p1lay
    61     REAL, DIMENSION(klon), INTENT(IN)       :: tq_cdrag
    62     REAL, DIMENSION(klon), INTENT(IN)       :: precip_rain, precip_snow
    63     REAL, DIMENSION(klon), INTENT(IN)       :: temp_air, spechum
    64     REAL, DIMENSION(klon), INTENT(IN)       :: petAcoef, peqAcoef
    65     REAL, DIMENSION(klon), INTENT(IN)       :: petBcoef, peqBcoef
    66     REAL, DIMENSION(klon), INTENT(IN)       :: pref
    67     REAL, DIMENSION(klon), INTENT(IN)       :: u1, v1, gustiness
    68     REAL, DIMENSION(klon), INTENT(IN)       :: rugoro
    69     REAL, DIMENSION(klon), INTENT(IN)       :: swnet, lwnet
    70 #ifdef ISO
    71     REAL, DIMENSION(ntiso,klon), INTENT(IN) :: xtprecip_rain, xtprecip_snow
    72     REAL, DIMENSION(ntiso,klon), INTENT(IN) :: xtspechum   
     59    REAL, DIMENSION(knon), INTENT(IN)       :: tsurf
     60    REAL, DIMENSION(knon), INTENT(IN)       :: p1lay
     61    REAL, DIMENSION(knon), INTENT(IN)       :: tq_cdrag
     62    REAL, DIMENSION(knon), INTENT(IN)       :: precip_rain, precip_snow
     63    REAL, DIMENSION(knon), INTENT(IN)       :: temp_air, spechum
     64    REAL, DIMENSION(knon), INTENT(IN)       :: petAcoef, peqAcoef
     65    REAL, DIMENSION(knon), INTENT(IN)       :: petBcoef, peqBcoef
     66    REAL, DIMENSION(knon), INTENT(IN)       :: pref
     67    REAL, DIMENSION(knon), INTENT(IN)       :: u1, v1, gustiness
     68    REAL, DIMENSION(knon), INTENT(IN)       :: rugoro
     69    REAL, DIMENSION(knon), INTENT(IN)       :: swnet, lwnet
     70#ifdef ISO
     71    REAL, DIMENSION(ntiso,knon), INTENT(IN) :: xtprecip_rain, xtprecip_snow
     72    REAL, DIMENSION(ntiso,knon), INTENT(IN) :: xtspechum   
    7373#endif
    7474
    7575! In/Output variables
    7676!****************************************************************************************
    77     REAL, DIMENSION(klon), INTENT(INOUT)          :: snow, qsol
    78     REAL, DIMENSION(klon), INTENT(INOUT)          :: agesno
    79     REAL, DIMENSION(klon, nsoilmx), INTENT(INOUT) :: tsoil
    80 #ifdef ISO
    81     REAL, DIMENSION(niso,klon), INTENT(INOUT)       :: xtsnow,xtsol
     77    REAL, DIMENSION(knon), INTENT(INOUT)          :: snow, qsol
     78    REAL, DIMENSION(knon), INTENT(INOUT)          :: agesno
     79    REAL, DIMENSION(knon, nsoilmx), INTENT(INOUT) :: tsoil
     80#ifdef ISO
     81    REAL, DIMENSION(niso,knon), INTENT(INOUT)       :: xtsnow,xtsol
    8282#endif
    8383
    8484! Output variables
    8585!****************************************************************************************
    86     REAL, DIMENSION(klon), INTENT(OUT)       :: qsurf
    87     REAL, DIMENSION(klon), INTENT(OUT)       :: z0_new
    88     REAL, DIMENSION(klon), INTENT(OUT)       :: alb1_new, alb2_new
    89     REAL, DIMENSION(klon), INTENT(OUT)       :: evap, fluxsens, fluxlat
    90     REAL, DIMENSION(klon), INTENT(OUT)       :: tsurf_new
    91     REAL, DIMENSION(klon), INTENT(OUT)       :: dflux_s, dflux_l     
    92 #ifdef ISO
    93     REAL, DIMENSION(ntiso,klon), INTENT(OUT) :: xtevap
    94     REAL, DIMENSION(klon),       INTENT(OUT) :: h1
    95     REAL, DIMENSION(niso,klon),  INTENT(OUT) :: xtrunoff_diag
    96     REAL, DIMENSION(klon),       INTENT(OUT) :: runoff_diag
    97     REAL, DIMENSION(niso,klon),  INTENT(IN)  :: Rland_ice
     86    REAL, DIMENSION(knon), INTENT(OUT)       :: qsurf
     87    REAL, DIMENSION(knon), INTENT(OUT)       :: z0_new
     88    REAL, DIMENSION(knon), INTENT(OUT)       :: alb1_new, alb2_new
     89    REAL, DIMENSION(knon), INTENT(OUT)       :: evap, fluxsens, fluxlat
     90    REAL, DIMENSION(knon), INTENT(OUT)       :: tsurf_new
     91    REAL, DIMENSION(knon), INTENT(OUT)       :: dflux_s, dflux_l     
     92#ifdef ISO
     93    REAL, DIMENSION(ntiso,knon), INTENT(OUT) :: xtevap
     94    REAL, DIMENSION(knon),       INTENT(OUT) :: h1
     95    REAL, DIMENSION(niso,knon),  INTENT(OUT) :: xtrunoff_diag
     96    REAL, DIMENSION(knon),       INTENT(OUT) :: runoff_diag
     97    REAL, DIMENSION(niso,knon),  INTENT(IN)  :: Rland_ice
    9898#endif
    9999
    100100! Local variables
    101101!****************************************************************************************
    102     REAL, DIMENSION(klon) :: soilcap, soilflux
    103     REAL, DIMENSION(klon) :: cal, beta, dif_grnd, capsol
    104     REAL, DIMENSION(klon) :: alb_neig, alb_lim, icesub
    105     REAL, DIMENSION(klon) :: zfra
    106     REAL, DIMENSION(klon) :: radsol       ! total net radiance at surface
    107     REAL, DIMENSION(klon) :: u0, v0, u1_lay, v1_lay
    108     REAL, DIMENSION(klon) :: dummy_riverflow,dummy_coastalflow
     102    REAL, DIMENSION(knon) :: soilcap, soilflux
     103    REAL, DIMENSION(knon) :: cal, beta, dif_grnd, capsol
     104    REAL, DIMENSION(knon) :: alb_neig, alb_lim, icesub
     105    REAL, DIMENSION(knon) :: zfra
     106    REAL, DIMENSION(knon) :: radsol       ! total net radiance at surface
     107    REAL, DIMENSION(knon) :: u0, v0, u1_lay, v1_lay
     108    REAL, DIMENSION(knon) :: dummy_riverflow,dummy_coastalflow
    109109    INTEGER               :: i
    110110#ifdef ISO
    111111    INTEGER               :: ixt
    112     REAL, DIMENSION(niso,klon) :: xtsnow_prec,xtsol_prec
    113     REAL, DIMENSION(klon) :: snow_prec,qsol_prec
     112    REAL, DIMENSION(niso,knon) :: xtsnow_prec,xtsol_prec
     113    REAL, DIMENSION(knon) :: snow_prec,qsol_prec
    114114    REAL, PARAMETER       :: t_coup = 273.15
    115     REAL, DIMENSION(klon) :: fq_fonte_diag
    116     REAL, DIMENSION(klon) :: fqfonte_diag
    117     REAL, DIMENSION(klon) :: snow_evap_diag
    118     REAL, DIMENSION(klon) :: fqcalving_diag
     115    REAL, DIMENSION(knon) :: fq_fonte_diag
     116    REAL, DIMENSION(knon) :: fqfonte_diag
     117    REAL, DIMENSION(knon) :: snow_evap_diag
     118    REAL, DIMENSION(knon) :: fqcalving_diag
    119119    REAL                  :: max_eau_sol_diag 
    120     REAL, DIMENSION(klon) :: run_off_lic_diag
     120    REAL, DIMENSION(knon) :: run_off_lic_diag
    121121    REAL :: coeff_rel_diag
    122122#endif
     
    284284        !write(*,*) 'snow_evap_diag(1)=',snow_evap_diag(1)
    285285#endif         
    286         CALL calcul_iso_surf_ter_vectall(klon,knon, &
     286        CALL calcul_iso_surf_ter_vectall(knon,knon, &
    287287     &           evap,snow_evap_diag,snow, &
    288288     &           fq_fonte_diag,fqfonte_diag,dtime,precip_rain,xtprecip_rain, &
     
    302302!* Calculate the age of snow
    303303!
    304     CALL albsno(klon,knon,dtime,agesno(:),alb_neig(:), precip_snow(:)) 
     304    CALL albsno(knon,knon,dtime,agesno(:),alb_neig(:), precip_snow(:)) 
    305305   
    306306    WHERE (snow(1 : knon) .LT. 0.0001) agesno(1 : knon) = 0.
Note: See TracChangeset for help on using the changeset viewer.