Changeset 2299 for trunk/LMDZ.GENERIC


Ignore:
Timestamp:
Apr 27, 2020, 4:39:37 PM (5 years ago)
Author:
dbardet
Message:

27/04/2017 (r2299) == DB

Add non-orographic gravity waves drag parameterization (Flott scheme adpated from the Earth GCM)

It can be called using 'calllott_nonoro=.true.' in callphys.def, and set the maximum value of the Eliassen-Plam flux 'epflux_max'.
Cumulated output fields are du_nonoro, dv_nonoro (winds tendency due to GW drag), east_gwstress and west_gwstress (stress profile in esatward and westward direction due to GW drag)
These variables are added in Xhisitns and start files.

Location:
trunk/LMDZ.GENERIC/libf/phystd
Files:
1 added
6 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.GENERIC/libf/phystd/callkeys_mod.F90

    r2297 r2299  
    6161      logical,save :: haze
    6262!$OMP THREADPRIVATE(photochem)
     63      logical,save :: calllott_nonoro
     64      logical,save :: gwd_convective_source
     65!$OMP THREADPRIVATE(calllott_nonoro,gwd_convective_source)
    6366
    6467      integer,save :: iddist
     
    135138      real,save :: surfemis
    136139!$OMP THREADPRIVATE(surfalbedo,surfemis)
     140      real,save :: epflux_max
     141!$OMP THREADPRIVATE(epflux_max)
    137142
    138143      logical,save :: iscallphys=.false.!existence of callphys.def
  • trunk/LMDZ.GENERIC/libf/phystd/inifis_mod.F90

    r2297 r2299  
    2222  use planetwide_mod, only: planetwide_sumval
    2323  use callkeys_mod
     24  use ioipsl_getin_p_mod, only : getin_p
    2425  use mod_phys_lmdz_para, only : is_parallel
    2526
     
    290291     write(*,*) " calladj = ",calladj
    291292
     293     write(*,*)"call Lott's non-oro GWs parameterisation scheme ?"
     294     calllott_nonoro=.false. ! default value
     295     call getin_p("calllott_nonoro",calllott_nonoro)
     296     write(*,*)" calllott_nonoro = ",calllott_nonoro
     297     
     298     write(*,*)"Max Value of EP flux at launching altitude"
     299     epflux_max=0.0                ! default value
     300     call getin_p("epflux_max",epflux_max)
     301     write(*,*)"epflux_max = ",epflux_max
     302
    292303     write(*,*) "call thermal plume model ?"
    293304     calltherm=.false. ! default value
  • trunk/LMDZ.GENERIC/libf/phystd/phyetat0_mod.F90

    r1763 r2299  
    2222  use slab_ice_h, only: noceanmx
    2323  use callkeys_mod, only: CLFvarying,surfalbedo,surfemis
    24 
     24  use nonoro_gwd_ran_mod, only: du_nonoro_gwd, dv_nonoro_gwd, &
     25                                east_gwstress, west_gwstress
    2526  implicit none
    2627
     
    389390  call soil_settings(nid_start,ngrid,nsoil,tsurf,tsoil,indextime)
    390391endif ! of if (startphy_file)
     392
     393! Non-orographic gravity waves
     394if (startphy_file) then
     395   call get_field("du_nonoro_gwd",du_nonoro_gwd,found,indextime)
     396   if (.not.found) then
     397      write(*,*) "phyetat0: <du_nonoro_gwd> not in file"
     398      du_nonoro_gwd(:,:)=0.
     399   else
     400      write(*,*) "phyetat0: Memory of zonal wind tendency due to non-orographic GW"
     401      write(*,*) " <du_nonoro_gwd> range:", &
     402             minval(du_nonoro_gwd), maxval(du_nonoro_gwd)
     403   endif
     404endif ! of if (startphy_file)
     405if (startphy_file) then
     406   call get_field("dv_nonoro_gwd",dv_nonoro_gwd,found,indextime)
     407   if (.not.found) then
     408      write(*,*) "phyetat0: <dv_nonoro_gwd> not in file"
     409      dv_nonoro_gwd(:,:)=0.
     410   else
     411      write(*,*) "phyetat0: Memory of meridional wind tendency due to non-orographic GW"
     412      write(*,*) " <dv_nonoro_gwd> range:", &
     413             minval(dv_nonoro_gwd), maxval(dv_nonoro_gwd)
     414   endif
     415endif ! of if (startphy_file)
     416if (startphy_file) then
     417   call get_field("east_gwstress",east_gwstress,found,indextime)
     418   if (.not.found) then
     419      write(*,*) "phyetat0: <east_gwstress> not in file"
     420      east_gwstress(:,:)=0.
     421   else
     422      write(*,*) "phyetat0: Memory of eastward stress profile due to non-orographic GW"
     423      write(*,*) " <east_gwstress> range:", &
     424             minval(east_gwstress), maxval(east_gwstress)
     425   endif
     426endif ! of if (startphy_file)
     427if (startphy_file) then
     428   call get_field("west_gwstress",west_gwstress,found,indextime)
     429   if (.not.found) then
     430      write(*,*) "phyetat0: <west_gwstress> not in file"
     431      west_gwstress(:,:)=0.
     432   else
     433      write(*,*) "phyetat0: Memory of westward stress profile due to non-orographic GW"
     434      write(*,*) " <west_gwstress> range:", &
     435             minval(west_gwstress), maxval(west_gwstress)
     436   endif
     437endif ! of if (startphy_file)
    391438!
    392439! close file:
  • trunk/LMDZ.GENERIC/libf/phystd/phyredem.F90

    r1800 r2299  
    142142  use tracer_h, only: noms
    143143  use slab_ice_h, only: noceanmx
    144   use callkeys_mod, only: ok_slab_ocean
     144  use callkeys_mod, only: ok_slab_ocean, calllott_nonoro
     145  use nonoro_gwd_ran_mod, only: du_nonoro_gwd, dv_nonoro_gwd, &
     146                                east_gwstress, west_gwstress
    145147
    146148  implicit none
     
    208210    enddo
    209211  endif ! of if (nq>0)
     212
     213! Non-orographic gavity waves
     214if (calllott_nonoro) then
     215   call put_field("du_nonoro_gwd","Zonal wind tendency due to GW",du_nonoro_gwd)
     216   call put_field("dv_nonoro_gwd","Meridional wind tendency due to GW",dv_nonoro_gwd)
     217   call put_field("east_gwstress","Eastward stress profile due to GW",east_gwstress)
     218   call put_field("west_gwstress","Westward stress profile due to GW",west_gwstress)
     219endif
     220
    210221! close file
    211222      CALL close_restartphy
  • trunk/LMDZ.GENERIC/libf/phystd/phys_state_var_mod.F90

    r2133 r2299  
    1818                        zmea, zstd, zsig, zgam, zthe
    1919      use turb_mod, only: q2,sensibFlux,wstar,ustar,tstar,hfmax_th,zmax_th
     20      use nonoro_gwd_ran_mod, only: ini_nonoro_gwd_ran, end_nonoro_gwd_ran
    2021
    2122      real,allocatable,dimension(:,:),save :: ztprevious ! Previous loop Atmospheric Temperature (K)
     
    179180        allocate(hfmax_th(klon))
    180181        allocate(zmax_th(klon))
    181 
     182        ! allocate arrays in "nonoro_gwd_ran_mod"
     183        call ini_nonoro_gwd_ran(klon,klev)
    182184END SUBROUTINE phys_state_var_init
    183185
     
    251253        deallocate(hfmax_th)
    252254        deallocate(zmax_th)
    253 
     255        ! deallocate arrays in "nonoro_gwd_ran_mod"
     256        call end_nonoro_gwd_ran
    254257
    255258END SUBROUTINE phys_state_var_end
  • trunk/LMDZ.GENERIC/libf/phystd/physiq_mod.F90

    r2232 r2299  
    4848      use time_phylmdz_mod, only: daysec
    4949      use callkeys_mod
     50      use nonoro_gwd_ran_mod, only: nonoro_gwd_ran
    5051      use conc_mod
    5152      use phys_state_var_mod
     
    410411      integer num_run
    411412      logical,save :: ice_update
     413!  Non-oro GW tendencies
     414      REAL d_u_hin(ngrid,nlayer), d_v_hin(ngrid,nlayer)
     415      REAL d_t_hin(ngrid,nlayer)
     416!  Diagnostics 2D of gw_nonoro
     417      REAL zustrhi(ngrid), zvstrhi(ngrid)
    412418
    413419
     
    497503         endif
    498504#endif
    499 
    500505         if (pday.ne.day_ini) then
    501            write(*,*) "ERROR in physiq.F90:"
    502            write(*,*) "bad synchronization between physics and dynamics"
    503            write(*,*) "dynamics day: ",pday
    504            write(*,*) "physics day:  ",day_ini
    505            stop
     506             write(*,*) "ERROR in physiq.F90:"
     507             write(*,*) "bad synchronization between physics and dynamics"
     508             write(*,*) "dynamics day: ",pday
     509             write(*,*) "physics day:  ",day_ini
     510             stop
    506511         endif
    507512
     
    680685         if (ngrid.ne.1) then ! Note : no need to create a restart file in 1d.
    681686            call physdem0("restartfi.nc",longitude,latitude,nsoilmx,ngrid,nlayer,nq, &
    682                           ptimestep,pday+nday,time_phys,cell_area,          &
    683                           albedo_bareground,inertiedat,zmea,zstd,zsig,zgam,zthe)
     687                         ptimestep,pday+nday,time_phys,cell_area,          &
     688                         albedo_bareground,inertiedat,zmea,zstd,zsig,zgam,zthe)
    684689         endif
    685690#endif         
     
    12391244         
    12401245      endif ! end of 'calladj'
     1246!----------------------------------------------
     1247!   Non orographic Gravity Waves:
     1248!---------------------------------------------
     1249      IF (calllott_nonoro) THEN
     1250
     1251         CALL nonoro_gwd_ran(ngrid,nlayer,ptimestep,pplay,  &
     1252                    zmax_th,                                &! max altitude reached by thermals (m)
     1253                    pt, pu, pv,                             &
     1254                    pdt, pdu, pdv,                          &
     1255                    zustrhi,zvstrhi,                        &
     1256                    d_t_hin, d_u_hin, d_v_hin)
     1257
     1258!  Update tendencies
     1259         pdt(1:ngrid,1:nlayer) = pdt(1:ngrid,1:nlayer)      &
     1260                               + d_t_hin(1:ngrid,1:nlayer)
     1261!        d_t_hin(:,:)= d_t_hin(:,:)/ptimestep ! K/s (for outputs?)
     1262         pdu(1:ngrid,1:nlayer) = pdu(1:ngrid,1:nlayer)      &
     1263                               + d_u_hin(1:ngrid,1:nlayer)
     1264!        d_u_hin(:,:)= d_u_hin(:,:)/ptimestep ! (m/s)/s (for outputs?)
     1265         pdv(1:ngrid,1:nlayer) = pdv(1:ngrid,1:nlayer)      &
     1266                               + d_v_hin(1:ngrid,1:nlayer)
     1267!        d_v_hin(:,:)= d_v_hin(:,:)/ptimestep ! (m/s)/s (for outputs?)
     1268         print*,'du_nonoro: max ', maxval(d_u_hin), 'min ', minval(d_u_hin)
     1269         print*,'dv_nonoro: max ', maxval(d_v_hin), 'min ', minval(d_v_hin)
     1270
     1271      ENDIF ! of IF (calllott_nonoro)
     1272
     1273
    12411274     
    12421275!-----------------------------------------------
     
    21122145         call writediagfi(ngrid,'fraca','Updraft fraction','', 3, fraca)
    21132146      endif
     2147
     2148!        GW non-oro outputs
     2149      if (calllott_nonoro) then
     2150         call WRITEDIAGFI(ngrid,"dugwno","GW non-oro dU","m/s2", 3,d_u_hin/ptimestep)
     2151         call WRITEDIAGFI(ngrid,"dvgwno","GW non-oro dV","m/s2", 3,d_v_hin/ptimestep)
     2152      endif
    21142153     
    21152154      ! Total energy balance diagnostics
     
    21892228        !call writediagfi(ngrid,"zdtsw","SW heating","T s-1",3,zdtsw)
    21902229        !call writediagfi(ngrid,"zdtlw","LW heating","T s-1",3,zdtlw)
    2191         !call writediagfi(ngrid,"dtrad","radiative heating","K s-1",3,dtrad)
     2230        call writediagfi(ngrid,"dtrad","radiative heating","K s-1",3,dtrad)
    21922231        ! call writediagfi(ngrid,"zdtdyn","Dyn. heating","T s-1",3,zdtdyn)
    21932232       
Note: See TracChangeset for help on using the changeset viewer.