Changeset 2955 for LMDZ5/trunk/libf


Ignore:
Timestamp:
Jul 17, 2017, 5:52:31 PM (7 years ago)
Author:
musat
Message:

Ajout modifs de Rodrigo Guzman et Marine Bonazolla dans la version COSP/CMIP6
IM

Location:
LMDZ5/trunk/libf/phylmd/cosp
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • LMDZ5/trunk/libf/phylmd/cosp/cosp_constants.F90

    r2713 r2955  
    5454
    5555    ! Number of possible output variables
    56     integer,parameter :: N_OUT_LIST = 65
    57     integer,parameter :: N3D = 10
    58     integer,parameter :: N2D = 14
    59     integer,parameter :: N1D = 40
     56    integer,parameter :: N_OUT_LIST = 74 !OPAQ 65+7 !TIBO 72+2
     57    integer,parameter :: N3D = 11                   !TIBO 10+1
     58    integer,parameter :: N2D = 19        !OPAQ 14+4 !TIBO 18+1
     59    integer,parameter :: N1D = 43        !OPAQ 40+3
    6060
    6161    ! Value for forward model result from a level that is under the ground
     
    9696    ! Other constants
    9797    integer,parameter :: LIDAR_NCAT    =   4
     98    integer,parameter :: LIDAR_NTYPE   =   3 !OPAQ
    9899    integer,parameter :: PARASOL_NREFL =   5 ! parasol
    99100    real,parameter,dimension(PARASOL_NREFL) :: PARASOL_SZA = (/0.0, 20.0, 40.0, 60.0, 80.0/)
  • LMDZ5/trunk/libf/phylmd/cosp/cosp_output_mod.F90

    r2944 r2955  
    103103         "clcalipsotmp", "Lidar Cloud Fraction", "%", (/ ('', i=1, 3) /))
    104104
     105  TYPE(ctrl_outcosp), SAVE :: o_clopaquecalipso = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &  !OPAQ
     106         "clopaquecalipso", "Lidar Opaque Cloud Fraction", "%", (/ ('', i=1, 3) /))             !OPAQ
     107  TYPE(ctrl_outcosp), SAVE :: o_clthincalipso = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &    !OPAQ
     108         "clthincalipso", "Lidar Thin Cloud Fraction", "%", (/ ('', i=1, 3) /))                 !OPAQ
     109  TYPE(ctrl_outcosp), SAVE :: o_clzopaquecalipso = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), & !OPAQ
     110         "clzopaquecalipso", "Lidar mean opacity altitude", "m", (/ ('', i=1, 3) /))            !OPAQ
     111  TYPE(ctrl_outcosp), SAVE :: o_clcalipsoopaque = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &  !OPAQ
     112         "clcalipsoopaque", "Lidar Opaque profile Cloud Fraction", "%", (/ ('', i=1, 3) /))     !OPAQ
     113  TYPE(ctrl_outcosp), SAVE :: o_clcalipsothin = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &    !OPAQ
     114         "clcalipsothin", "Lidar Thin profile Cloud Fraction", "%", (/ ('', i=1, 3) /))         !OPAQ
     115  TYPE(ctrl_outcosp), SAVE :: o_clcalipsozopaque = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), & !OPAQ
     116         "clcalipsozopaque", "Lidar z_opaque Fraction", "%", (/ ('', i=1, 3) /))                !OPAQ
     117  TYPE(ctrl_outcosp), SAVE :: o_clcalipsoopacity = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), & !OPAQ
     118         "clcalipsoopacity", "Lidar opacity Fraction", "%", (/ ('', i=1, 3) /))                 !OPAQ
     119
     120  TYPE(ctrl_outcosp), SAVE :: o_proftemp = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &         !TIBO
     121         "proftemp", "Temperature profiles (40 lev)", "K", (/ ('', i=1, 3) /))                  !TIBO
     122  TYPE(ctrl_outcosp), SAVE :: o_profSR = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &           !TIBO
     123         "profSR", "Lidar Scattering Ratio profiles (532 nm)", "1", (/ ('', i=1, 3) /))         !TIBO
     124
    105125! Radar Cloudsat
    106126  TYPE(ctrl_outcosp), SAVE :: o_cfadDbze94 = ctrl_outcosp((/ .TRUE., .TRUE., .TRUE. /), &
     
    376396      CALL histvert(cosp_nidfiles(iff),"pressure2","pressure","mb",7,ISCCP_PC,nvertisccp(iff),"down")
    377397
    378       CALL histvert(cosp_nidfiles(iff),"column","column","count",Ncolumns,column_ax(1:Ncolumns),nvertcol(iff))
     398      CALL histvert(cosp_nidfiles(iff),"column","column","count",Ncolumns,column_ax,nvertcol(iff)) !DBUG
    379399
    380400      CALL histvert(cosp_nidfiles(iff),"temp","temperature","C",LIDAR_NTEMP,LIDAR_PHASE_TEMP,nverttemp(iff))
  • LMDZ5/trunk/libf/phylmd/cosp/cosp_output_write_mod.F90

    r2867 r2955  
    104104      stlidar%lidarcld(ip,k)=missing_val
    105105     endif
     106     if(stlidar%proftemp(ip,k).eq.R_UNDEF)then !TIBO
     107      stlidar%proftemp(ip,k)=missing_val       !TIBO
     108     endif                                     !TIBO
    106109     enddo
    107110
     
    113116      enddo
    114117     enddo
    115    enddo
     118
     119     do ii= 1,Ncolumns                               !TIBO
     120      do ip = 1,Npoints                              !TIBO
     121!       if(stlidar%profSR(ip,ii,k).eq.R_UNDEF)then    !TIBO
     122!        stlidar%profSR(ip,ii,k)=missing_val          !TIBO
     123       if(stlidar%profSR(ip,k,ii).eq.R_UNDEF)then    !TIBO2
     124        stlidar%profSR(ip,k,ii)=missing_val          !TIBO2
     125       endif                                         !TIBO
     126      enddo                                          !TIBO
     127     enddo                                           !TIBO
     128  enddo
    116129
    117130  do ip = 1,Npoints
     
    138151   enddo
    139152
     153   do k = 1,LIDAR_NTYPE                       !OPAQ
     154    do ip = 1,Npoints                         !OPAQ
     155     if(stlidar%cldtype(ip,k).eq.R_UNDEF)then !OPAQ
     156       stlidar%cldtype(ip,k)=missing_val      !OPAQ
     157     endif                                    !OPAQ
     158    enddo                                     !OPAQ
     159   enddo                                      !OPAQ
     160
    140161! AI 11 / 2015
    141162
     
    144165   where(stlidar%cldlayerphase == R_UNDEF) stlidar%cldlayerphase = missing_val
    145166   where(stlidar%lidarcldphase == R_UNDEF) stlidar%lidarcldphase = missing_val
     167   where(stlidar%lidarcldtype == R_UNDEF) stlidar%lidarcldtype = missing_val   !OPAQ
    146168   where(stlidar%lidarcldtmp == R_UNDEF) stlidar%lidarcldtmp = missing_val
    147169   
     
    176198   CALL histwrite3d_cosp(o_clcalipsotmpun,stlidar%lidarcldtmp(:,:,4),nverttemp)
    177199
     200   CALL histwrite2d_cosp(o_clopaquecalipso,stlidar%cldtype(:,1))               !OPAQ
     201   CALL histwrite2d_cosp(o_clthincalipso,stlidar%cldtype(:,2))                 !OPAQ
     202   CALL histwrite2d_cosp(o_clzopaquecalipso,stlidar%cldtype(:,3))              !OPAQ
     203
     204   CALL histwrite3d_cosp(o_clcalipsoopaque,stlidar%lidarcldtype(:,:,1),nvert)  !OPAQ
     205   CALL histwrite3d_cosp(o_clcalipsothin,stlidar%lidarcldtype(:,:,2),nvert)    !OPAQ
     206   CALL histwrite3d_cosp(o_clcalipsozopaque,stlidar%lidarcldtype(:,:,3),nvert) !OPAQ
     207   CALL histwrite3d_cosp(o_clcalipsoopacity,stlidar%lidarcldtype(:,:,4),nvert) !OPAQ
     208
     209   CALL histwrite3d_cosp(o_proftemp,stlidar%proftemp,nvert)                    !TIBO
     210
    178211#ifdef CPP_XIOS
    179212   CALL histwrite4d_cosp(o_cfad_lidarsr532,stlidar%cfad_sr)
     213   CALL histwrite4d_cosp(o_profSR,stlidar%profSR)                              !TIBO
    180214#else
    181215   do icl=1,SR_BINS
    182216      CALL histwrite3d_cosp(o_cfad_lidarsr532,stlidar%cfad_sr(:,icl,:),nvert,icl)
    183217   enddo
    184 #endif
    185 
    186    CALL histwrite3d_cosp(o_parasol_refl,stlidar%parasolrefl,nvertp)
     218   do icl=1,Ncolumns                                                              !TIBO
     219      CALL histwrite3d_cosp(o_profSR,stlidar%profSR(:,icl,:),nvert,icl)           !TIBO
     220   enddo                                                                          !TIBO
     221     CALL histwrite3d_cosp(o_parasol_refl,stlidar%parasolrefl,nvertp)
     222#endif
     223
    187224   do k=1,PARASOL_NREFL
    188225    do ip=1, Npoints
  • LMDZ5/trunk/libf/phylmd/cosp/cosp_stats.F90

    r2428 r2955  
    121121                                           Nlr,vgrid%zl,vgrid%zu,temp_out)
    122122            temp_c(:,:) = temp_out(:,1,:)
     123            stlidar%proftemp = temp_c                                     !TIBO
     124            where (stlidar%proftemp  < 150.) stlidar%proftemp   = R_UNDEF !TIBO
     125            where (stlidar%proftemp  > 350.) stlidar%proftemp   = R_UNDEF !TIBO
    123126
    124127            call cosp_change_vertical_grid(Npoints,1,Nlevels,gbx%zlev,gbx%zlev_half,ph_in, &
     
    131134                            ,LIDAR_UNDEF,ok_lidar_cfad &
    132135                            ,stlidar%cfad_sr,stlidar%srbval &
    133                             ,LIDAR_NCAT,stlidar%lidarcld,stlidar%lidarcldphase &
    134                             ,stlidar%cldlayer,stlidar%cldlayerphase,stlidar%lidarcldtmp &
    135                             ,stlidar%parasolrefl)
     136                            ,LIDAR_NCAT,LIDAR_NTYPE,stlidar%lidarcld,stlidar%lidarcldtype & !OPAQ
     137                            ,stlidar%lidarcldphase,stlidar%cldlayer,stlidar%cldtype &       !OPAQ
     138                            ,stlidar%cldlayerphase,stlidar%lidarcldtmp &                    !OPAQ
     139                            ,stlidar%parasolrefl,vgrid%z,stlidar%profSR)                    !OPAQ !TIBO
    136140        endif
    137141
     
    140144                                    temp_c,betatot_out,betaperptot_out,betamol_c,Ze_out, &
    141145                                    stradar%lidar_only_freq_cloud,stradar%radar_lidar_tcc)
    142         deallocate(temp_out,temp_c,betaperptot_out)
     146        deallocate(temp_in,temp_out,temp_c,betaperptot_out) !TIBO +temp_in
    143147
    144148        ! Deallocate arrays at coarse resolution
     
    154158                        ,LIDAR_UNDEF,ok_lidar_cfad &
    155159                        ,stlidar%cfad_sr,stlidar%srbval &
    156                         ,LIDAR_NCAT,stlidar%lidarcld,stlidar%lidarcldphase,stlidar%cldlayer,stlidar%cldlayerphase &
    157                         ,stlidar%lidarcldtmp,stlidar%parasolrefl)
     160                        ,LIDAR_NCAT,LIDAR_NTYPE,stlidar%lidarcld,stlidar%lidarcldtype & !OPAQ
     161                        ,stlidar%lidarcldphase,stlidar%cldlayer,stlidar%cldtype &       !OPAQ
     162                        ,stlidar%cldlayerphase,stlidar%lidarcldtmp &                    !OPAQ
     163                        ,stlidar%parasolrefl,vgrid%z,stlidar%profSR)                    !OPAQ !TIBO
    158164        !++++++++++++ Lidar-only cloud amount and lidar&radar total cloud mount ++++++++++++++++
    159165        if (cfg%Lradar_sim.and.cfg%Llidar_sim) call cosp_lidar_only_cloud(Npoints,Ncolumns,Nlr, &
     
    163169   ! Replace undef
    164170   where (stlidar%cfad_sr   == LIDAR_UNDEF) stlidar%cfad_sr   = R_UNDEF
     171   where (stlidar%profSR   == LIDAR_UNDEF) stlidar%profSR   = R_UNDEF !TIBO
    165172   where (stlidar%lidarcld  == LIDAR_UNDEF) stlidar%lidarcld  = R_UNDEF
     173   where (stlidar%lidarcldtype  == LIDAR_UNDEF) stlidar%lidarcldtype  = R_UNDEF !OPAQ
    166174   where (stlidar%cldlayer  == LIDAR_UNDEF) stlidar%cldlayer  = R_UNDEF
     175   where (stlidar%cldtype  == LIDAR_UNDEF) stlidar%cldtype  = R_UNDEF           !OPAQ
    167176   where (stlidar%parasolrefl == LIDAR_UNDEF) stlidar%parasolrefl = R_UNDEF
    168177   where (stlidar%cldlayerphase  == LIDAR_UNDEF) stlidar%cldlayerphase  = R_UNDEF
  • LMDZ5/trunk/libf/phylmd/cosp/cosp_types.F90

    r2713 r2955  
    5151                Lcltmodis,Lclwmodis,Lclimodis,Lclhmodis,Lclmmodis,Lcllmodis,Ltautmodis,Ltauwmodis,Ltauimodis,Ltautlogmodis, &
    5252                Ltauwlogmodis,Ltauilogmodis,Lreffclwmodis,Lreffclimodis,Lpctmodis,Llwpmodis, &
    53                 Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis
     53                Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis,Lclopaquecalipso,Lclthincalipso, & !OPAQ (2)
     54                Lclzopaquecalipso,Lclcalipsoopaque,Lclcalipsothin,Lclcalipsozopaque,    & !OPAQ (4)
     55                Lclcalipsoopacity,LprofSR,Lproftemp                                       !OPAQ (1) !TIBO (2)
    5456
    5557     character(len=32) :: out_list(N_OUT_LIST)
     
    199201    ! Arrays with dimensions (Npoints,Nlevels)
    200202    real, dimension(:,:),pointer :: lidarcld    ! 3D "lidar" cloud fraction
     203    real, dimension(:,:),pointer :: proftemp    ! Temperature profiles 40 levs !TIBO
    201204    ! Arrays with dimensions (Npoints,LIDAR_NCAT)
    202205    real, dimension(:,:),pointer :: cldlayer      ! low, mid, high-level, total lidar cloud cover
    203    ! Arrays with dimensions (Npoints,Nlevels,Nphase)
     206    ! Arrays with dimensions (Npoints,LIDAR_NTYPE)                                               !OPAQ
     207    real, dimension(:,:),pointer :: cldtype       ! opaque and thin cloud covers, z_opaque       !OPAQ
     208    ! Arrays with dimensions (Npoints,Nlevels,Nphase)
    204209    real, dimension(:,:,:),pointer :: lidarcldphase    ! 3D "lidar" phase cloud fraction
    205      ! Arrays with dimensions (Npoints,LIDAR_NCAT,Nphase)
     210    ! Arrays with dimensions (Npoints,Nlevels,LIDAR_NTYPE+1)                                     !OPAQ
     211    real, dimension(:,:,:),pointer :: lidarcldtype     ! 3D "lidar" OPAQ type fraction + opacity !OPAQ
     212    ! Arrays with dimensions (Npoints,LIDAR_NCAT,Nphase)
    206213    real, dimension(:,:,:),pointer :: cldlayerphase      ! low, mid, high-level lidar phase cloud cover
    207214    ! Arrays with dimensions (Npoints,Ntemps,Nphase)
     
    209216    ! Arrays with dimensions (Npoints,PARASOL_NREFL)
    210217    real, dimension(:,:),pointer :: parasolrefl   ! mean parasol reflectance
     218!    ! Arrays with dimensions (Npoints,Ncolumns,Nlevels)                     !TIBO
     219!    real, dimension(:,:,:),pointer :: profSR      ! subcolumns for each day !TIBO
     220    ! Arrays with dimensions (Npoints,Nlevels,Ncolumns)                     !TIBO2
     221    real, dimension(:,:,:),pointer :: profSR      ! subcolumns for each day !TIBO2
    211222
    212223  END TYPE COSP_LIDARSTATS
     
    803814    allocate(x%lidarcldphase(i,k,6),x%lidarcldtmp(i,LIDAR_NTEMP,5),&
    804815             x%cldlayerphase(i,LIDAR_NCAT,6))
     816    allocate(x%lidarcldtype(i,k,LIDAR_NTYPE+1),x%cldtype(i,LIDAR_NTYPE)) !OPAQ
     817!    allocate(x%profSR(i,j,k),x%proftemp(i,k))                            !TIBO
     818    allocate(x%profSR(i,k,j),x%proftemp(i,k))                            !TIBO2
    805819    ! --- Initialise to zero ---
    806820    x%srbval    = 0.0
     
    812826    x%cldlayerphase  = 0.0
    813827    x%lidarcldtmp  = 0.0
     828    x%lidarcldtype  = 0.0 !OPAQ
     829    x%cldtype  = 0.0      !OPAQ
     830    x%profSR   = 0.0      !TIBO
     831    x%proftemp = 0.0      !TIBO
    814832
    815833   END SUBROUTINE CONSTRUCT_COSP_LIDARSTATS
     
    823841    deallocate(x%srbval, x%cfad_sr, x%lidarcld, x%cldlayer, x%parasolrefl)
    824842    deallocate(x%cldlayerphase, x%lidarcldtmp, x%lidarcldphase)
     843    deallocate(x%lidarcldtype, x%cldtype) !OPAQ
     844    deallocate(x%profSR, x%proftemp)      !TIBO
    825845  END SUBROUTINE FREE_COSP_LIDARSTATS
    826846
     
    13671387    y%cldlayerphase(iy(1):iy(2),:,:)  = x%cldlayerphase(ix(1):ix(2),:,:)
    13681388    y%lidarcldtmp(iy(1):iy(2),:,:)    = x%lidarcldtmp(ix(1):ix(2),:,:)
     1389    y%lidarcldtype(iy(1):iy(2),:,:)    = x%lidarcldtype(ix(1):ix(2),:,:) !OPAQ
     1390    y%cldtype(iy(1):iy(2),:)           = x%cldtype(ix(1):ix(2),:)        !OPAQ
     1391    y%profSR(iy(1):iy(2),:,:)          = x%profSR(ix(1):ix(2),:,:)       !TIBO
     1392    y%proftemp(iy(1):iy(2),:)          = x%proftemp(ix(1):ix(2),:)       !TIBO
    13691393END SUBROUTINE COSP_LIDARSTATS_CPSECTION
    13701394!%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
     
    15991623    ! Arrays with dimensions (Npoints,SR_BINS,Nlevels)
    16001624    print *, 'shape(x%cfad_sr): ',shape(x%cfad_sr)
     1625!    ! Arrays with dimensions (Npoints,Ncolumns,Nlevels) !TIBO
     1626!    print *, 'shape(x%profSR): ',shape(x%profSR)        !TIBO
     1627    ! Arrays with dimensions (Npoints,Nlevels,Ncolumns) !TIBO2
     1628    print *, 'shape(x%profSR): ',shape(x%profSR)        !TIBO2
    16011629    ! Arrays with dimensions (Npoints,Nlevels)
    16021630    print *, 'shape(x%lidarcld): ',shape(x%lidarcld)
     1631    print *, 'shape(x%proftemp): ',shape(x%proftemp)    !TIBO
    16031632    ! Arrays with dimensions (Npoints,LIDAR_NCAT)
    16041633    print *, 'shape(x%cldlayer): ',shape(x%cldlayer)
     1634    ! Arrays with dimensions (Npoints,LIDAR_NTYPE)            !OPAQ
     1635    print *, 'shape(x%cldtype): ',shape(x%cldtype)            !OPAQ
    16051636    ! Arrays with dimensions (Npoints,PARASOL_NREFL)
    16061637    print *, 'shape(x%parasolrefl): ',shape(x%parasolrefl)
    16071638     ! Arrays with dimensions (Npoints,Nlevels,Nphase)
    16081639    print *, 'shape(x%lidarcldphase): ',shape(x%lidarcldphase)
     1640     ! Arrays with dimensions (Npoints,Nlevels,LIDAR_NTYPE+1) !OPAQ
     1641    print *, 'shape(x%lidarcldtype): ',shape(x%lidarcldtype)  !OPAQ
    16091642     ! Arrays with dimensions (Npoints,LIDAR_NCAT,Nphase)
    16101643    print *, 'shape(x%cldlayerphase): ',shape(x%cldlayerphase)
  • LMDZ5/trunk/libf/phylmd/cosp/lmd_ipsl_stats.F90

    r2428 r2955  
    3636      SUBROUTINE diag_lidar(npoints,ncol,llm,max_bin,nrefl &
    3737                  ,tmp,pnorm,pnorm_perp,pmol,refl,land,pplay,undef,ok_lidar_cfad &
    38                   ,cfad2,srbval,ncat,lidarcld,lidarcldphase,cldlayer,cldlayerphase &
    39                   ,lidarcldtmp,parasolrefl)
     38                  ,cfad2,srbval,ncat,ntype,lidarcld,lidarcldtype,lidarcldphase,cldlayer & !OPAQ
     39                  ,cldtype,cldlayerphase,lidarcldtmp,parasolrefl,vgrid_z,profSR)          !OPAQ !TIBO
    4040!
    4141! -----------------------------------------------------------------------------------
     
    8282      integer max_bin               ! nb of bins for SR CFADs
    8383      integer ncat                  ! nb of cloud layer types (low,mid,high,total)
     84      integer ntype                 ! nb of OPAQ products (opaque and thin clouds, z_opaque) !OPAQ
    8485      integer nrefl                 ! nb of solar zenith angles for parasol reflectances
    8586
     
    9394      real tmp(npoints,llm)         ! temp at each levels
    9495      real pnorm_perp(npoints,ncol,llm)  ! lidar perpendicular ATB
     96      real vgrid_z(llm)             ! mid-level altitude of the output vertical grid         !OPAQ
    9597
    9698! c outputs :
    9799      real lidarcld(npoints,llm)     ! 3D "lidar" cloud fraction
     100      real lidarcldtype(npoints,llm,ntype+1)   ! 3D "lidar" OPAQ type fraction + opacity     !OPAQ
    98101      real sub(npoints,llm)     ! 3D "lidar" indice
    99102      real cldlayer(npoints,ncat)    ! "lidar" cloud layer fraction (low, mid, high, total)
     103      real cldtype(npoints,ntype)  ! "lidar" OPAQ type covers (opaque/thin cloud + z_opaque) !OPAQ
    100104
    101105      real cfad2(npoints,max_bin,llm) ! CFADs of SR
    102106      real srbval(max_bin)           ! SR bins in CFADs
    103107      real parasolrefl(npoints,nrefl)! grid-averaged parasol reflectance
     108!     real profSR(npoints,ncol,llm)  ! tableau avec les subcolumns SR !TIBO
     109      real profSR(npoints,llm,ncol)  ! tableau avec les subcolumns SR !TIBO2
    104110
    105111! c threshold for cloud detection :
     
    110116      real S_att
    111117      parameter (S_att = 0.01)
     118!      parameter (S_att = 0.06)  !OPAQ ! Threshold for "surface detection" equivalent
    112119
    113120! c local variables :
     
    147154        end where
    148155         x3d(:,ic,:) = x3d_c
     156!       profSR(:,ic,:) = x3d(:,ic,:) !TIBO
     157        profSR(:,:,ic) = x3d(:,ic,:) !TIBO2
    149158      enddo
    150159
     
    157166              tmp,x3d,pnorm,pnorm_perp,pplay, S_att,S_cld,S_cld_att,undef,lidarcld, &
    158167              cldlayer,lidarcldphase,sub,cldlayerphase,lidarcldtmp)
     168
     169    CALL COSP_OPAQ(npoints,ncol,llm,ntype,x3d,S_cld,undef,lidarcldtype,            & !OPAQ
     170                   cldtype,vgrid_z)                                                  !OPAQ
    159171
    160172! c -------------------------------------------------------
     
    983995! ---------------------------------------------------------------
    984996
     997! BEGINNING OF OPAQ CHANGES
     998    ! ####################################################################################
     999    ! SUBROUTINE cosp_opaq
     1000    ! Conventions: Ntype must be equal to 3 (opaque cloud, thin cloud, z_opaque)
     1001    ! ####################################################################################
     1002    SUBROUTINE COSP_OPAQ(Npoints,Ncolumns,Nlevels,Ntype,x,S_cld,undef,lidarcldtype,   &
     1003                         cldtype,vgrid_z)
     1004
     1005      IMPLICIT NONE
     1006! Input arguments
     1007      integer Npoints,Ncolumns,Nlevels,Ntype
     1008      real x(Npoints,Ncolumns,Nlevels)
     1009      real S_cld
     1010      real undef
     1011      real vgrid_z(Nlevels)
     1012! Output :
     1013      real lidarcldtype(Npoints,Nlevels,Ntype+1) ! 3D "lidar" OPAQ type + opacity fraction
     1014      real cldtype(Npoints,Ntype)              ! opaque and thin cloud covers, z_opaque
     1015! Local variables
     1016      integer ip, k, iz, ic, zopac
     1017      real p1
     1018      real cldy(Npoints,Ncolumns,Nlevels)
     1019      real cldyopaq(Npoints,Ncolumns,Nlevels)
     1020      real srok(Npoints,Ncolumns,Nlevels)
     1021      real srokopaq(Npoints,Ncolumns,Nlevels)
     1022      real cldlay(Npoints,Ncolumns,Ntype+1)  ! opaque, thin, z_opaque and all cloud cover
     1023      real nsublay(Npoints,Ncolumns,Ntype+1) ! opaque, thin, z_opaque and all cloud cover
     1024      real nsublayer(Npoints,Ntype)
     1025      real nsub(Npoints,Nlevels)
     1026      real nsubopaq(Npoints,Nlevels)
     1027      real S_att_opaq
     1028      real S_att
     1029 
     1030    ! ####################################################################################
     1031        ! 1) Initialize   
     1032    ! ####################################################################################
     1033    cldtype               = 0.0
     1034    lidarcldtype          = 0.0
     1035    nsub                  = 0.0
     1036    nsubopaq              = 0.0
     1037    cldlay                = 0.0
     1038    nsublay               = 0.0
     1039    nsublayer             = 0.0
     1040    S_att_opaq            = 0.06 ! Fully Attenuated threshold, from Guzman et al. 2017, JGR-A
     1041    S_att                 = 0.01
     1042
     1043    ! ####################################################################################
     1044    ! 2) Cloud detection and Fully attenuated layer detection
     1045    ! ####################################################################################
     1046    do k=1,Nlevels
     1047       ! Cloud detection at subgrid-scale:
     1048       where ( (x(:,:,k) .gt. S_cld) .and. (x(:,:,k) .ne. undef) )
     1049          cldy(:,:,k)=1.0
     1050       elsewhere
     1051          cldy(:,:,k)=0.0
     1052       endwhere
     1053       ! Fully attenuated layer detection at subgrid-scale:
     1054       where ( (x(:,:,k) .gt. 0.0) .and. (x(:,:,k) .lt. S_att_opaq) .and. (x(:,:,k) .ne. undef) )
     1055          cldyopaq(:,:,k)=1.0
     1056       elsewhere
     1057          cldyopaq(:,:,k)=0.0
     1058       endwhere
     1059
     1060       ! Number of useful sub-column layers:
     1061       where ( (x(:,:,k) .gt. S_att) .and. (x(:,:,k) .ne. undef) )
     1062          srok(:,:,k)=1.0
     1063       elsewhere
     1064          srok(:,:,k)=0.0
     1065       endwhere
     1066       ! Number of useful sub-columns layers for z_opaque 3D fraction:
     1067       where ( (x(:,:,k) .gt. 0.0) .and. (x(:,:,k) .ne. undef) )
     1068          srokopaq(:,:,k)=1.0
     1069       elsewhere
     1070          srokopaq(:,:,k)=0.0
     1071       endwhere
     1072    enddo
     1073
     1074    ! ####################################################################################
     1075    ! 3) Grid-box 3D OPAQ product fraction and cloud type cover (opaque/thin) + mean z_opaque
     1076    ! ####################################################################################
     1077
     1078    do k= Nlevels,1,-1
     1079       do ic = 1, Ncolumns
     1080          do ip = 1, Npoints
     1081
     1082             cldlay(ip,ic,1)   = MAX(cldlay(ip,ic,1),cldyopaq(ip,ic,k)) ! Opaque clouds
     1083             cldlay(ip,ic,4)   = MAX(cldlay(ip,ic,4),cldy(ip,ic,k))     ! All clouds
     1084
     1085             nsublay(ip,ic,1)  = MAX(nsublay(ip,ic,1),srok(ip,ic,k))
     1086             nsublay(ip,ic,2)  = MAX(nsublay(ip,ic,2),srok(ip,ic,k))
     1087!             nsublay(ip,ic,4)  = MAX(nsublay(ip,ic,4),srok(ip,ic,k))
     1088             nsub(ip,k)        = nsub(ip,k) + srok(ip,ic,k)
     1089             nsubopaq(ip,k)    = nsubopaq(ip,k) + srokopaq(ip,ic,k)
     1090
     1091          enddo
     1092       enddo
     1093    enddo   
     1094
     1095! OPAQ variables
     1096     do ic = 1, Ncolumns
     1097        do ip = 1, Npoints
     1098
     1099     ! Declaring non-opaque cloudy profiles as thin cloud profiles
     1100           if ( (cldlay(ip,ic,4) .eq. 1.0) .and. (cldlay(ip,ic,1) .eq. 0.0) ) then
     1101              cldlay(ip,ic,2)  =  1.0
     1102           endif
     1103
     1104     ! Filling in 3D and 2D variables
     1105
     1106     ! Opaque cloud profiles
     1107           if ( cldlay(ip,ic,1) .eq. 1.0 ) then
     1108              zopac = 0.0
     1109              do k=2,Nlevels
     1110     ! Declaring opaque cloud fraction and z_opaque altitude for 3D and 2D variables
     1111                 if ( (cldy(ip,ic,k) .eq. 1.0) .and. (zopac .eq. 0.0) ) then
     1112                    lidarcldtype(ip,k-1,3) = lidarcldtype(ip,k-1,3) + 1.0
     1113                    cldlay(ip,ic,3)        = vgrid_z(k-1) !z_opaque altitude
     1114                    nsublay(ip,ic,3)       = 1.0
     1115                    zopac = 1.0
     1116                 endif
     1117                 if ( cldy(ip,ic,k) .eq. 1.0 ) then
     1118                    lidarcldtype(ip,k,1)   = lidarcldtype(ip,k,1) + 1.0
     1119                 endif
     1120              enddo
     1121           endif
     1122
     1123     ! Thin cloud profiles
     1124           if ( cldlay(ip,ic,2) .eq. 1.0 ) then
     1125              do k=1,Nlevels
     1126     ! Declaring thin cloud fraction for 3D variable
     1127                 if ( cldy(ip,ic,k) .eq. 1.0 ) then
     1128                    lidarcldtype(ip,k,2) = lidarcldtype(ip,k,2) + 1.0
     1129                 endif
     1130              enddo
     1131           endif
     1132
     1133       enddo
     1134    enddo   
     1135
     1136    ! 3D cloud types fraction (opaque=1 and thin=2)
     1137    where ( nsub(:,:) .gt. 0.0 )
     1138       lidarcldtype(:,:,1) = lidarcldtype(:,:,1)/nsub(:,:)
     1139       lidarcldtype(:,:,2) = lidarcldtype(:,:,2)/nsub(:,:)
     1140    elsewhere
     1141       lidarcldtype(:,:,1) = undef
     1142       lidarcldtype(:,:,2) = undef
     1143    endwhere
     1144    ! 3D z_opaque fraction (=3)
     1145    where ( nsubopaq(:,:) .gt. 0.0 )
     1146       lidarcldtype(:,:,3) = lidarcldtype(:,:,3)/nsubopaq(:,:)
     1147    elsewhere
     1148       lidarcldtype(:,:,3) = undef
     1149    endwhere
     1150    ! 3D opacity fraction (=4) !Summing z_opaque fraction from TOA(k=Nlevels) to SFC(k=1)
     1151       lidarcldtype(:,Nlevels,4) = lidarcldtype(:,Nlevels,3)
     1152    do ip = 1, Npoints
     1153        do k = Nlevels-1, 1, -1
     1154           if ( lidarcldtype(ip,k,3) .ne. undef ) then
     1155              lidarcldtype(ip,k,4) = lidarcldtype(ip,k+1,4) + lidarcldtype(ip,k,3)
     1156           endif
     1157        enddo
     1158    enddo
     1159    where ( nsubopaq(:,:) .eq. 0.0 )
     1160       lidarcldtype(:,:,4) = undef
     1161    endwhere
     1162
     1163    ! Layered cloud types (opaque, thin and z_opaque 2D variables)
     1164
     1165    do iz = 1, Ntype
     1166       do ic = 1, Ncolumns
     1167          cldtype(:,iz)   = cldtype(:,iz)   + cldlay(:,ic,iz)
     1168          nsublayer(:,iz) = nsublayer(:,iz) + nsublay(:,ic,iz)
     1169       enddo
     1170    enddo
     1171    where (nsublayer(:,:) .gt. 0.0)
     1172       cldtype(:,:) = cldtype(:,:)/nsublayer(:,:)
     1173    elsewhere
     1174       cldtype(:,:) = undef
     1175    endwhere
     1176
     1177  END SUBROUTINE COSP_OPAQ
     1178! END OF OPAQ CHANGES
     1179
    9851180
    9861181END MODULE MOD_LMD_IPSL_STATS
  • LMDZ5/trunk/libf/phylmd/cosp/read_cosp_output_nl.F90

    r2713 r2955  
    4141             Lcltmodis,Lclwmodis,Lclimodis,Lclhmodis,Lclmmodis,Lcllmodis,Ltautmodis,Ltauwmodis,Ltauimodis,Ltautlogmodis, &
    4242             Ltauwlogmodis,Ltauilogmodis,Lreffclwmodis,Lreffclimodis,Lpctmodis,Llwpmodis, &
    43              Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis
     43             Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis,Lclopaquecalipso,Lclthincalipso,      &           !OPAQ (2)
     44             Lclzopaquecalipso,Lclcalipsoopaque,Lclcalipsothin,Lclcalipsozopaque,Lclcalipsoopacity, & !OPAQ (5)
     45             LprofSR,Lproftemp                                                                        !TIBO (2)
    4446
    4547  namelist/COSP_OUTPUT/Lradar_sim,Llidar_sim,Lisccp_sim,Lmodis_sim,Lmisr_sim,Lrttov_sim, &
     
    5759             Lcltmodis,Lclwmodis,Lclimodis,Lclhmodis,Lclmmodis,Lcllmodis,Ltautmodis,Ltauwmodis,Ltauimodis,Ltautlogmodis, &
    5860             Ltauwlogmodis,Ltauilogmodis,Lreffclwmodis,Lreffclimodis,Lpctmodis,Llwpmodis, &
    59              Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis
     61             Liwpmodis,Lclmodis,Lcrimodis,Lcrlmodis,Lclopaquecalipso,Lclthincalipso,      &           !OPAQ (2)
     62             Lclzopaquecalipso,Lclcalipsoopaque,Lclcalipsothin,Lclcalipsozopaque,Lclcalipsoopacity, & !OPAQ (5)
     63             LprofSR,Lproftemp                                                                        !TIBO (2)
    6064   
    6165  do i=1,N_OUT_LIST
     
    139143  CALL bcast(Lcrimodis)
    140144  CALL bcast(Lcrlmodis)
     145  CALL bcast(Lclopaquecalipso)  !OPAQ
     146  CALL bcast(Lclthincalipso)    !OPAQ
     147  CALL bcast(Lclzopaquecalipso) !OPAQ
     148  CALL bcast(Lclcalipsoopaque)  !OPAQ
     149  CALL bcast(Lclcalipsothin)    !OPAQ
     150  CALL bcast(Lclcalipsozopaque) !OPAQ
     151  CALL bcast(Lclcalipsoopacity) !OPAQ
     152  CALL bcast(LprofSR)           !TIBO
     153  CALL bcast(Lproftemp)         !TIBO
    141154
    142155!$OMP BARRIER
     
    185198    Lclmcalipsoun      = .false.
    186199    Lcltcalipsoun      = .false.
    187   endif
     200    Lclopaquecalipso   = .false. !OPAQ
     201    Lclthincalipso     = .false. !OPAQ
     202    Lclzopaquecalipso  = .false. !OPAQ
     203    Lclcalipsoopaque   = .false. !OPAQ
     204    Lclcalipsothin     = .false. !OPAQ
     205    Lclcalipsozopaque  = .false. !OPAQ
     206    Lclcalipsoopacity  = .false. !OPAQ
     207    LprofSR            = .false. !TIBO
     208    Lproftemp          = .false. !TIBO
     209  endif
     210
    188211  if (.not.Lisccp_sim) then
    189212    Lalbisccp       = .false.
     
    390413  i = i+1
    391414  if (Lcrlmodis)         cfg%out_list(i) = 'crlmodis'
     415
     416  i = i+1                                                            !OPAQ
     417  if (Lclopaquecalipso)         cfg%out_list(i) = 'clopaquecalipso'  !OPAQ
     418  i = i+1                                                            !OPAQ
     419  if (Lclthincalipso)           cfg%out_list(i) = 'clthincalipso'    !OPAQ
     420  i = i+1                                                            !OPAQ
     421  if (Lclzopaquecalipso)        cfg%out_list(i) = 'clzopaquecalipso' !OPAQ
     422  i = i+1                                                            !OPAQ
     423  if (Lclcalipsoopaque)         cfg%out_list(i) = 'clcalipsoopaque'  !OPAQ
     424  i = i+1                                                            !OPAQ
     425  if (Lclcalipsothin)           cfg%out_list(i) = 'clcalipsothin'    !OPAQ
     426  i = i+1                                                            !OPAQ
     427  if (Lclcalipsozopaque)        cfg%out_list(i) = 'clcalipsozopaque' !OPAQ
     428  i = i+1                                                            !OPAQ
     429  if (Lclcalipsoopacity)        cfg%out_list(i) = 'clcalipsoopacity' !OPAQ
     430  i = i+1                                                            !TIBO
     431  if (LprofSR)                  cfg%out_list(i) = 'profSR'           !TIBO
     432  i = i+1                                                            !TIBO
     433  if (Lproftemp)                cfg%out_list(i) = 'proftemp'         !TIBO
    392434   
    393435  if (i /= N_OUT_LIST) then
     
    441483  cfg%Lcltlidarradar = Lcltlidarradar
    442484  cfg%LparasolRefl = LparasolRefl
     485  cfg%Lclopaquecalipso  = Lclopaquecalipso  !OPAQ
     486  cfg%Lclthincalipso    = Lclthincalipso    !OPAQ
     487  cfg%Lclzopaquecalipso = Lclzopaquecalipso !OPAQ
     488  cfg%Lclcalipsoopaque  = Lclcalipsoopaque  !OPAQ
     489  cfg%Lclcalipsothin    = Lclcalipsothin    !OPAQ
     490  cfg%Lclcalipsozopaque = Lclcalipsozopaque !OPAQ
     491  cfg%Lclcalipsoopacity = Lclcalipsoopacity !OPAQ
     492  cfg%LprofSR           = LprofSR           !TIBO
     493  cfg%Lproftemp         = Lproftemp         !TIBO
    443494  ! MISR simulator 
    444495  cfg%LclMISR = LclMISR
Note: See TracChangeset for help on using the changeset viewer.