subroutine totalcloudfrac(ngrid,nq,rneb,totalrneb,pplev,pq,tau) use watercommon_h use comdiurn_h USE comgeomfi_h USE tracer_h implicit none !================================================================== ! ! Purpose ! ------- ! Calculates the total cloud fraction ! ! Authors ! ------- ! Adapted from the LMDTERRE code by B Charnay (2010) ! !================================================================== #include "dimensions.h" #include "dimphys.h" #include "comcstfi.h" #include "callkeys.h" integer ngrid, nq real rneb(ngrid,nlayermx) ! cloud fraction real pplev(ngrid,nlayermx+1) real pq(ngrid,nlayermx,nq) real tau(ngrid,nlayermx) real totalrneb(ngrid) ! total cloud fraction real, dimension(nlayermx+1) :: masse integer, parameter :: recovery=7 integer ltau_max real massetot ! hypothesis behind recovery. value: ! 1 = random recovery ! 2 = maximal recovery ! 3 = minimal recovery ! 4 = fixed recovery ! 5 = recovery on the thicker layer ! Local variables integer ig, l real clear,tau_min real, parameter :: tau_c=0.1 !threshold of optical depth for the calculation of total cloud fraction real rneb2(nlayermx) do ig=1,ngrid totalrneb(ig) = 0. if (recovery.eq.1) then clear = (1.-rneb(ig,1)) do l=2,nlayermx clear = clear*(1.-rneb(ig,l)) enddo totalrneb(ig) = 1.-clear elseif (recovery.eq.2) then totalrneb(ig) = rneb(ig,1) do l=2,14 !nlayermx totalrneb(ig) = max(rneb(ig,l),totalrneb(ig)) enddo elseif (recovery.eq.3) then totalrneb(ig) = rneb(ig,1) do l=2,nlayermx totalrneb(ig) = min(rneb(ig,l),totalrneb(ig)) enddo elseif (recovery.eq.4) then totalrneb(ig) = CLFfixval elseif (recovery.eq.5) then totalrneb(ig) = rneb(ig,1) do l=1,nlayermx masse(l)=pq(ig,l,igcm_h2o_ice)*(pplev(ig,l)-pplev(ig,l+1)) enddo ltau_max=maxloc(masse,dim=1) totalrneb(ig) = rneb(ig,ltau_max) elseif (recovery.eq.6) then totalrneb(ig) = 0. do l=1,nlayermx masse(l)=pq(ig,l,igcm_h2o_ice)*(pplev(ig,l)-pplev(ig,l+1)) masse(l)=max(masse(l),0.) enddo massetot=sum(masse,dim=1) do l=1,nlayermx totalrneb(ig) = totalrneb(ig)+rneb(ig,l)*masse(l)/massetot enddo elseif (recovery.eq.7) then rneb2(:)=rneb(ig,1:nlayermx) tau_min=MIN(tau_c,MAXVAL(tau(ig,1:nlayermx))/2.) do l=1,nlayermx if(tau(ig,l)