C $Header: /u/gcmpack/MITgcm/pkg/fizhi/fizhi_lsm.F,v 1.7 2005/06/17 16:51:24 ce107 Exp $
C $Name:  $

#include "FIZHI_OPTIONS.h"
      SUBROUTINE TILE (
     I                 NCH, DTSTEP, ITYP, TRAINL,TRAINC, TSNOW,  UM,
     I                 ETURB,  DEDQA,  DEDTC,  HSTURB, DHSDQA, DHSDTC,
     I                 TM,     QM,     CD,     SUNANG, PARDIR,  PARDIF,
     I                 SWNET,  HLWDWN, PSUR,    ZLAI,   GREEN,  Z2,
     I                 SQSCAT, RSOIL1, RSOIL2,   RDC,    U2FAC,
     I                 QSATTC, DQSDTC, ALWRAD, BLWRAD,
     U                 TC, TD, QA, SWET1, SWET2, SWET3, CAPAC, SNOW,
     O                 EVAP, SHFLUX, RUNOFF, BOMB,
     O                 EINT,   ESOI,   EVEG,   ESNO, SMELT, HLATN,
     O                 HLWUP,GDRAIN,RUNSRF,FWSOIL,
     O                 STRDG1, STRDG2, STRDG3, STRDG4,
     O                 STRDG5, STRDG6, STRDG7, STRDG8, STRDG9
     &                )

C   SCCS VERSION @(#)lsm.f	1.2 11/3/92 

C****
C****       This subroutine computes the outgoing fluxes of sensible and
C**** latent heat from the land surface and updates the surface prognostic
C**** variables.
C****
      IMPLICIT NONE
C
C****
#include "sibber.h"
C****
      INTEGER NCH
      INTEGER ITYP(NCH)
      _RL  DTSTEP,  TRAINL(NCH), TRAINC(NCH), TSNOW(NCH), UM(NCH),
     &       ETURB(NCH),  DEDQA(NCH), HSTURB(NCH), DHSDTC(NCH),
     &         TM (NCH),     CD(NCH), SUNANG(NCH), DHSDQA(NCH),
     &         QM (NCH), PARDIR(NCH), PARDIF(NCH),  SWNET(NCH),
     &      HLWDWN(NCH),   PSUR(NCH),   ZLAI(NCH),  GREEN(NCH),
     &          Z2(NCH), SQSCAT(NCH),  DEDTC(NCH)
      _RL  RSOIL1(NCH), RSOIL2(NCH),    RDC(NCH),  U2FAC(NCH),
     &     QSATTC(NCH), DQSDTC(NCH),  ALWRAD(NCH), BLWRAD(NCH),
     &          TC(NCH),     TD(NCH),     QA(NCH),   BOMB(NCH),
     &       SWET1(NCH),  SWET2(NCH),  SWET3(NCH),  CAPAC(NCH), 
     &        SNOW(NCH),   EVAP(NCH), SHFLUX(NCH), RUNOFF(NCH)
      _RL   EINT(NCH),    ESOI(NCH),   EVEG(NCH),   ESNO(NCH),
     &     STRDG1(NCH),  STRDG2(NCH), STRDG3(NCH), STRDG4(NCH),
     &     STRDG5(NCH),  STRDG6(NCH), STRDG7(NCH), STRDG8(NCH),
     &     STRDG9(NCH),
     &      SMELT(NCH),   HLATN(NCH),  HLWUP(NCH), GDRAIN(NCH),
     &     RUNSRF(NCH),  FWSOIL(NCH)
C****
      INTEGER ChNo
      _RL     SWET(nch,NLAY),   VGPSAT(NTYPS),   VGCSAT (NTYPS),
     &       VGZDEP(NLAY,NTYPS),   VGSLOP(NTYPS),            DELTC,
     &                    DELEA,    VGPH1(NTYPS),     VGPH2(NTYPS),
     &            VGRPLN(NTYPS),    CSOIL0(NTYPS),          WSOI12,
     &             VGBEE(NTYPS),    DELZ12(NTYPS),
     &            DELZ23(NTYPS)
C****

      _RL PHLAY(nch,NLAY), AKLAY(nch,NLAY), SWET12(nch),
     &      CSOIL(nch),
     &       RCUN(nch),     VPDSTR(nch),   ESATTX(nch),
     &       VPDSTX(nch),   VGBEEX(nch)
      _RL EMAXRT(nch), VGWMAX(NLAY,NTYPS), FTEMP(nch),
     &        PHR(nch),      SOILCO(nch),    RC(nch),
     &        EAX(nch),          TX(nch),   RCX(nch),
     &     DRCDTC(nch),      SATCAP(nch),   PAR(nch),
     &       PDIR(nch),       DUMMY(nch)
      _RL FTEMPX(nch),  DRCDEA(nch), VGPSAX(nch), VGCSAX(nch),
     &                VGZDEX(NLAY,nch), VGSLOX(nch), VGPH1X(nch),
     &     VGPH2X(nch),  VGRPLX(nch)
      _RL  DEDEA(nch),  DHSDEA(nch),     EM(nch), ESATTC(nch),
     &     DESDTC(nch),      EA(nch),     RA(nch),   ALHX(nch),
     &     WETEQ1(nch), WETEQ2(nch),
     &        RX1(nch),     RX2(nch), SNWFRC(nch), POTFRC(nch),
     &     ESNFRC(nch),  EIRFRC(nch),   FCAN(nch),  EPFRC,
     &     DEFCIT, EADJST, RTBS
      _RL cmpbug

C****
      DATA VGWMAX   /8.4,    621.6,      840.0,
     2               8.4,    621.6,      840.0,
     3               8.4,    621.6,      840.0,
     4               8.4,    197.4,      420.0,
     5               8.704,  204.5,      435.2,
     6               8.4,     71.4,      420.0,
     7               4.000,   4.000,    130.56,
     8               4.000,   4.000,    130.56,
     9               8.704,   73.984,    130.56,
     1               4.000,   4.000,    130.56
     &              /
      DATA VGBEE /    4.,    4.,    4.,    4.,  1.69,    4., 
     &                4.,  1.69,  1.69, 1.69/
C      DATA VGBEE /    7.,    7.,    7.,    7.,  1.69,    7., 
C     &                7.,  1.69,  1.69, 1.69/
c      DATA VGBEE /    4.,    4.,    4.,    4.,  0.95,    4., 
c     &                4.,  0.95,  0.95, 0.95/
C      DATA VGBEE /7, 7, 7, 7, 2, 7, 7, 4, 2, 4/
      DATA VGPSAT/    -0.281,     -0.281,       -0.281,       -0.281,
     5                -0.073,     -0.281,       -0.281,       -0.073,
     9                -0.073 ,    -0.073/
C      DATA VGPSAT/    -0.086,     -0.086,       -0.086,       -0.086,
C     5                -0.073,     -0.086,       -0.086,       -0.073,
C     9                -0.073 ,    -0.073/
c      DATA VGPSAT/    -0.281,     -0.281,       -0.281,       -0.281,
c     5                -0.014,     -0.281,       -0.281,       -0.014,
c     9                -0.014 ,    -0.014/
c      DATA VGCSAT /  0.00002,  0.00002,    0.00002,    0.00002,
c     5               0.0000583,  0.00002,    0.00002,    0.0000583,
c     9               0.0000583,  0.0000583
c     &              /
      DATA VGCSAT /  0.0000012,  0.0000012,    0.0000012,    0.0000012,
     5               0.0000583,  0.0000012,    0.0000012,    0.0000583,
     9               0.0000583,  0.0000583
     &              /
C**** - - - - - - - -
C**** THE FOLLOWING 3 VARIABLES MUST MAINTAIN CONSISTENT VALUES.  ZDEP12(N) =
C****  (VGZDEP(1,N)+VGZDEP(2,N))/2. ; SIMILARLY FOR ZDEP23(N).
C****
      DATA VGZDEP /.02, 1.48, 2.00,
     2             .02, 1.48, 2.00,
     3             .02, 1.48, 2.00,
     4             .02,  .47, 1.00,
     5             .02,  .47, 1.00,
     6             .02,  .17, 1.00,
     7             .0092,  .0092,  .30,
     8             .0092,  .0092,  .30,
     9             .02,  .17,  .30,
     1             .0092,  .0092,  .30
     &            /
      DATA DELZ12 / 0.75, 0.75, 0.75, 0.245, 0.245, 0.095, 0.0092,
     8        0.0092, 0.095, 0.0092 /
      DATA DELZ23 / 1.74, 1.74, 1.74, 0.735, 0.735, 0.585, 0.155,
     8        0.155, 0.235, 0.155 /
C**** - - - - - - - -
      DATA VGSLOP /    .1736,     .1736,     .1736,     .1736,
     5                 1.000,     .1736,     .1736,     1.000,
     &                 1.000 , 1.000 /
c      DATA VGSLOP /    .1736,     .1736,     .1736,     .1736,
c     5                 .0872,     .1736,     .1736,     .0872,
c     &                 .0872 , .0872 /
c      DATA VGSLOP / 1., 1., 1.,  1., 1., 1.,  1., 1., 1.,1./
      DATA VGPH1 /     -100.,     -190.,     -200.,     -120.,
     5                 -200.,     -200.,     -200.,      -10.,
     9                  -10.,      -10. /
      DATA VGPH2 /     -500.,     -250.,     -250.,     -230.,
     5                 -400.,     -400.,     -250.,     -100.,
     9                 -100.,     -100. /
      DATA VGRPLN /0.245E+09, 0.245E+09, 0.245E+09, 0.250E+09,
     5             0.250E+09, 0.250E+09, 0.245E+09,   0.1E+09,
     9               0.1E+09, 0.100E+09 /
C**** 
      DATA DELTC /0.01/, DELEA /0.001/

c Note: SNWMID & CSOIL0 parameters modified from (Koster/Suarez) 
c       to obtain improved albedo, radswg, and annual/diurnal cycle (L.Takacs 2/17/00)
c ------------------------------------------------------------------------------------
      DATA CSOIL0 /175000.,175000.,175000.,175000.,175000.,
     .             175000.,175000.,120000.,175000., 70000./
#include "snwmid.h"

C****
C**** --------------------------------------------------------------------- 
C****
CFPP$ EXPAND (TMPFAC, RCANOP, SOIL, WUPDAT, SMFAC)
C****
C**** Expand data as specified by ITYP into arrays of size NCH.
C****
      DO 50 ChNo = 1, NCH
      BOMB(CHNO) = 0.
      VGBEEX(ChNo) = VGBEE(ITYP(ChNo))
      VGPSAX(ChNo) = VGPSAT(ITYP(ChNo))
      VGCSAX(ChNo) = VGCSAT(ITYP(ChNo))
      VGZDEX(SFCLY ,ChNo) = VGZDEP(SFCLY ,ITYP(ChNo))
      VGZDEX(ROOTLY,ChNo) = VGZDEP(ROOTLY,ITYP(ChNo))
      VGZDEX(RECHLY,ChNo) = VGZDEP(RECHLY,ITYP(ChNo))
      VGSLOX(ChNo) = VGSLOP(ITYP(ChNo))
      VGPH1X(ChNo) = VGPH1(ITYP(ChNo))
      VGPH2X(ChNo) = VGPH2(ITYP(ChNo))
      VGRPLX(ChNo) = VGRPLN(ITYP(ChNo))
  50  CONTINUE

C****
C**** Pre-process input arrays as necessary:

      DO 100 ChNo = 1, NCH

      DEDQA(CHNO)  = MAX(  DEDQA(CHNO), 500. _d 0/ALHE )
      DEDTC(CHNO)  = MAX(  DEDTC(CHNO),   0. _d 0)
      DHSDQA(CHNO) = MAX( DHSDQA(CHNO),   0. _d 0)
      DHSDTC(CHNO) = MAX( DHSDTC(CHNO), -10. _d 0)

      EM(CHNO)     = QM(CHNO) * PSUR(CHNO) / EPSILON
      EA(CHNO)     = QA(CHNO) * PSUR(CHNO) / EPSILON
      ESATTC(CHNO) = QSATTC(CHNO) * PSUR(CHNO) / EPSILON
      DESDTC(CHNO) = DQSDTC(CHNO) * PSUR(CHNO) / EPSILON
C      DEDEA(CHNO)  = DEDQA(CHNO) * EPSILON / ( PSUR(CHNO) * ALHX(CHNO) )
      DEDEA(CHNO)  = DEDQA(CHNO) * EPSILON / PSUR(CHNO)
      DHSDEA(CHNO) = DHSDQA(CHNO) * EPSILON / PSUR(CHNO)
C      DEDTC(CHNO)  = DEDTC(CHNO) / ALHX(CHNO)
C      ETURB(CHNO)  = ETURB(CHNO) / ALHX(CHNO)
      PAR(CHNO)    = (PARDIR(CHNO) + PARDIF(CHNO) + 1.E-20)
      PDIR(CHNO)   = PARDIR(CHNO) / PAR(CHNO)
      RA(CHNO)     = ONE / ( CD(CHNO) * UM(CHNO) )
      SATCAP(ChNo) = 0.1 * ZLAI(ChNo)
      CSOIL(CHNO)  = CSOIL0(ITYP(ChNo))
      SWET(ChNo,SFCLY ) = max( min(SWET1(ChNo),1. _d 0), 0. _d 0)
      SWET(ChNo,ROOTLY) = max( min(SWET2(ChNo),1. _d 0), 0. _d 0)
      SWET(ChNo,RECHLY) = max( min(SWET3(ChNo),1. _d 0), 0. _d 0)
      CAPAC(CHNO)       = max( min(CAPAC(ChNo),SATCAP(CHNO)), 0. _d 0)
C****

      SNWFRC(CHNO) = SNOW(CHNO) / ( SNOW(CHNO) + SNWMID(ITYP(CHNO)) )
      FCAN(CHNO) = MIN( 1. _d 0, MAX(0. _d 0,CAPAC(ChNo)/SATCAP(ChNo)) )
      POTFRC(CHNO)=1.-(1.-SNWFRC(CHNO))*(1.-FCAN(CHNO))


      WSOI12=SWET(ChNo,SFCLY ) * VGWMAX(SFCLY ,ITYP(ChNo)) +
     &       SWET(ChNo,ROOTLY) * VGWMAX(ROOTLY,ITYP(ChNo))
      SWET12(ChNo) = WSOI12 /
     &          (VGWMAX(SFCLY,ITYP(ChNo)) + VGWMAX(ROOTLY,ITYP(ChNo)))

      EMAXRT(CHNO) = ( SNOW(CHNO) + CAPAC(CHNO) + WSOI12 ) / DTSTEP

C****
      RUNOFF(CHNO) = 0.
      RUNSRF(CHNO) = 0.
C**** (SMELT is zeroed in FLUXES)
C      SMELT(CHNO)  = 0.
      FWSOIL(CHNO) = 0.
 100  CONTINUE

C****
C**** - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C****       STEP 1: COMPUTE EFFECTIVE RESISTANCE RC FOR ENERGY BALANCE.
C****          (RCUNST  computes the unstressed resistance,
C****           VPDFAC  computes the vapor pressure deficit stress term,
C****           TMPFAC  computes the temperature stress term,
C****           SOIL    computes soil moisture potentials and conds.,
C****           SMFAC   computes rc given a leaf water potential stress,
C****           RSURFP  computes rc given a parallel resist. from the
C****                   surface,
C****           RCANOP  computes rc corrected for snow and interception.)
C****

      CALL RCUNST (
     I             NCH, ITYP, SUNANG, SQSCAT, PDIR,
     I             PAR, ZLAI, GREEN,
     O             RCUN
     &            )

      CALL VPDFAC (
     I             NCH,  ITYP,  ESATTC, EA,   
     O             VPDSTR
     &            )

      CALL TMPFAC (
     I             NCH,  ITYP, TC,
     O             FTEMP
     &            )

      CALL SOIL (
     I           NCH, ITYP, SWET12, VGBEEX, VGPSAX, VGCSAX, DELZ12,
     O           PHR, SOILCO, DUMMY
     &          )

      cmpbug=0.

      CALL SMFAC (
     I            NCH,    ITYP,   ESATTC, EA,   PHR, SOILCO, RCUN,
     I            VPDSTR, FTEMP,  TC,     PSUR, Z2,  RSOIL1, RSOIL2,
     I            VGPH1X, VGPH2X, VGRPLX,
     O            RC
     &           )

      CALL RSURFP (
     I             NCH, UM, U2FAC, Z2, RDC, SWET(1,SFCLY),
     I             ESATTC, EA,
     U             RC,
     O             RX1, RX2
     &            )

      CALL RCANOP (
     I             NCH, CAPAC, SNOW, SATCAP, RA, ETURB, SNWFRC,
     I             POTFRC,
     U             RC
     &            )

C****
C**** -    -    -    -    -    -    -    -    -    -    -    -    -    -
C****
C**** Compute DRC/DT and DRC/DEA using temperature, v.p. perturbations:
C****

      DO 120 ChNo = 1, NCH
      TX(ChNo) = TC(ChNo) + DELTC
      ESATTX(ChNo) = ESATTC(ChNo) + DESDTC(CHNO) * DELTC
      EAX(ChNo) = EA(ChNo) + DELEA
  120 CONTINUE
C****
C**** temperature:
      CALL VPDFAC (NCH, ITYP, ESATTX, EA, VPDSTX)
      CALL TMPFAC (NCH, ITYP, TX, FTEMPX)
      CALL SMFAC (
     I            NCH,    ITYP,   ESATTX, EA,   PHR, SOILCO, RCUN,
     I            VPDSTX, FTEMPX, TX,     PSUR, Z2,  RSOIL1, RSOIL2,
     I            VGPH1X, VGPH2X, VGRPLX,
     O            RCX
     &           )
      CALL RSURFP (NCH, UM, U2FAC, Z2, RDC, SWET(1,SFCLY),
     I             ESATTX, EA,
     &             RCX,
     O             DUMMY,DUMMY
     &            )
      CALL RCANOP (NCH, CAPAC, SNOW, SATCAP, RA, ETURB, SNWFRC,
     &               POTFRC, RCX)
C****
      DO 125 ChNo = 1, NCH
      DRCDTC(ChNo) = (RCX(ChNo) - RC(ChNo)) / DELTC
  125 CONTINUE
C****
C**** vapor pressure:
      CALL VPDFAC (NCH, ITYP, ESATTC, EAX, VPDSTX)
      CALL SMFAC (
     I            NCH,    ITYP,  ESATTC, EAX,  PHR, SOILCO, RCUN,
     I            VPDSTX, FTEMP, TC,     PSUR, Z2,  RSOIL1, RSOIL2,
     I            VGPH1X, VGPH2X, VGRPLX,
     O            RCX
     &           )
      CALL RSURFP (NCH, UM, U2FAC, Z2, RDC, SWET(1,SFCLY),
     I             ESATTC, EAX,
     &             RCX,
     O             DUMMY,DUMMY
     &            )
      CALL RCANOP (NCH, CAPAC, SNOW, SATCAP, RA, ETURB, SNWFRC,
     &               POTFRC, RCX)
C****
      DO 150 ChNo = 1, NCH
      DRCDEA(ChNo) = (RCX(ChNo) - RC(ChNo)) / DELEA
  150 CONTINUE
C****

C****
C**** - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C****       STEP 2: Solve the energy balance at the surface.
C****
C****
C**** Determine effective latent heat of vaporization based on
C**** assumed fractional coverage of snow.  This requires the
C**** determination of the fractions of moisture taken from the various
C**** reservoirs:
C****         ESNFRC=fraction of total evap. coming from snow
C****         EIRFRC=fraction of total evap. coming from interception res.

      DO 200 CHNO=1,NCH
      RTBS=RX1(CHNO)*RX2(CHNO)/(RX1(CHNO)+RX2(CHNO))
      EPFRC=POTFRC(CHNO) * ( RA(CHNO) + RTBS ) /
     &                    ( RA(CHNO) + POTFRC(CHNO)*RTBS )
      ESNFRC(CHNO)=EPFRC*SNWFRC(CHNO)/
     &                      (SNWFRC(CHNO)+FCAN(CHNO)+1.E-20)
      EIRFRC(CHNO)=EPFRC*FCAN(CHNO)/(SNWFRC(CHNO)+FCAN(CHNO)+1.E-20)
      ALHX(CHNO) = (1.-ESNFRC(CHNO))*ALHE + ESNFRC(CHNO)*ALHS
  200 CONTINUE

      CALL FLUXES (
     I                NCH,   ITYP, DTSTEP, ESATTC, DESDTC,   ALHX, 
     I              ETURB,  DEDEA,  DEDTC, HSTURB, DHSDEA, DHSDTC, 
     I                 RC, DRCDEA, DRCDTC, 
     I              SWNET, HLWDWN, ALWRAD, BLWRAD, ESNFRC,
     I                 TM,     EM,  CSOIL,   PSUR, EMAXRT, VGWMAX,
     U                 TC,     TD,     EA,   SWET,   SNOW,
     O             RUNOFF,   EVAP, SHFLUX,  SMELT,  HLWUP, BOMB,STRDG1,
     O             STRDG2, STRDG3, STRDG4, STRDG5, STRDG6, STRDG7,
     O             STRDG8, STRDG9
     &            )
c****
C****
C**** - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C****       STEP 3: Update the water quantities in the soil and in the
C****          interception reservoir.
C****          (WUPDAT  reduces moisture contents using calculated
C****           evap.,
C****           GWATER  computes darcian flux of water between soil
C****           layers.)
C****

      CALL WUPDAT (
     I               NCH,   ITYP, DTSTEP,
     I               EVAP, SATCAP, VGWMAX, TC, RA, RC,
     I               RX1, RX2,ESNFRC,EIRFRC,
     U               CAPAC, SNOW, SWET, RUNOFF,
     O               EINT, ESOI, EVEG, ESNO, RUNSRF,FWSOIL
     &              )

C**** 
C**** Correct any energy balance inconsistency.
C****
      DO 300 CHNO=1,NCH
      IF(EVAP(CHNO) .GT. 0.) THEN
        EADJST=(ESNO(CHNO)/DTSTEP) - ESNFRC(CHNO)*EVAP(CHNO)
        SHFLUX(CHNO)=SHFLUX(CHNO)-EADJST*(ALHS-ALHE)
        ENDIF
  300 CONTINUE



      CALL SOIL (
     I             NCH,          ITYP,        SWET (1, SFCLY), VGBEEX,
     I             VGPSAX,       VGCSAX,      DELZ12,
     O             PHLAY(1,SFCLY), AKLAY(1,SFCLY),  DUMMY
     &            )
      CALL SOIL (
     I             NCH,          ITYP,        SWET(1,ROOTLY), VGBEEX,
     I             VGPSAX,       VGCSAX,      DELZ12,
     O             PHLAY(1,ROOTLY), AKLAY(1,ROOTLY),   WETEQ1
     &            )
      CALL SOIL (
     I             NCH,          ITYP,        SWET(1,RECHLY), VGBEEX,
     I             VGPSAX,       VGCSAX,      DELZ23,
     O             PHLAY(1,RECHLY), AKLAY(1,RECHLY),   WETEQ2
     &            )

      CALL GWATER (
     I             NCH, ITYP, VGWMAX, PHLAY, AKLAY, TC, DTSTEP,
     I             VGZDEX, VGSLOX, WETEQ1, WETEQ2,
     I             VGPSAX, VGCSAX,
     U             SWET, RUNOFF, GDRAIN
     &            )

C**** - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C****
C****       STEP 4: Allow precipitation to fill interception reservoir
C****          and top soil layer
C****

      CALL SOIL (
     I             NCH,          ITYP,        SWET(1,ROOTLY), VGBEEX,
     I             VGPSAX,       VGCSAX,      DELZ12,
     O             PHLAY(1,ROOTLY), AKLAY(1,ROOTLY),   WETEQ1
     &            )

      CALL INTERC (
     I             NCH, ITYP, DTSTEP, TRAINL, TRAINC, TSNOW, SATCAP,
     I             VGWMAX, CSOIL, WETEQ1,
     U             TC, CAPAC, SNOW, SWET, RUNOFF, RUNSRF,
     &             SMELT, FWSOIL
     &            )


C****
C****
C**** Process data for return to GCM:

      DO 2000 ChNo = 1, NCH
      QA(CHNO) = EA(CHNO) * EPSILON / PSUR(CHNO)
C      DEDTC(CHNO) = DEDTC(CHNO) * ALHX(CHNO)
C      ETURB(CHNO) = ETURB(CHNO) * ALHX(CHNO)
      HLATN (CHNO) = EVAP (CHNO) * ALHX(CHNO)
      SWET1(ChNo) = SWET(ChNo,SFCLY)
      SWET2(ChNo) = SWET(ChNo,ROOTLY)
      SWET3(ChNo) = SWET(ChNo,RECHLY)

      IF(SWET1(ChNo).LT.1.E-10) SWET1(CHNO) = 0.0
      IF(SWET2(ChNo).LT.1.E-10) SWET2(CHNO) = 0.0
      IF(SWET3(ChNo).LT.1.E-10) SWET3(CHNO) = 0.0
      IF(CAPAC(ChNo).LT.1.E-10) CAPAC(CHNO) = 0.0
      IF(SNOW (ChNo).LT.1.E-10) SNOW (CHNO) = 0.0
      IF(RUNOFF(ChNo).LT.1.E-10) RUNOFF(CHNO) = 0.0

      EINT(CHNO) = EINT(CHNO) * ALHE / DTSTEP
      ESOI(CHNO) = ESOI(CHNO) * ALHE / DTSTEP
      EVEG(CHNO) = EVEG(CHNO) * ALHE / DTSTEP
      ESNO(CHNO) = ESNO(CHNO) * ALHS / DTSTEP

      DEFCIT = EVAP(CHNO) * ( RC(CHNO) + RA(CHNO) )
CCOOMMSTRDG1(CHNO) = DEFCIT / RA(CHNO)
CCOOMMSTRDG2(CHNO) = DEFCIT / ( RA(CHNO) + RCUN(CHNO) )
CCOOMMSTRDG3(CHNO) = DEFCIT / ( RA(CHNO) + RCUN(CHNO)/VPDSTR(CHNO) )
CCOOMMSTRDG4(CHNO) = DEFCIT / ( RA(CHNO) +
CCOOMM                   RCUN(CHNO)/(VPDSTR(CHNO)*FTEMP(CHNO)) )

 2000 CONTINUE
C****

      RETURN
      END


C**** C**** [ END CHIP ] C**** C**** ----------------------------------------------------------------- C**** ///////////////////////////////////////////////////////////////// C**** ----------------------------------------------------------------- C**** C**** [ BEGIN INTERC ] C**** SUBROUTINE INTERC ( I NCH, ITYP, DTSTEP, TRAINL, TRAINC, I TSNOW, SATCAP, WMAX, CSOIL, WETEQ1, U TC, CAPAC, SNOW, SWET1, RUNOFF, RUNSRF, U SMELT, FWSOIL & ) C**** C**** This routine uses the precipitation forcing to determine C**** changes in interception, snowcover, and soil moisture storage. C**** C**** Note: In this formulation, rain that falls on frozen ground C**** runs-off, rather than freezes. C**** IMPLICIT NONE C**** #include "sibber.h" C**** INTEGER NCH INTEGER ITYP(NCH), ChNo _RL TRAINL(NCH), TRAINC(NCH), TSNOW(NCH), SATCAP(NCH), & WMAX(NLAY,NTYPS), TC(NCH), CSOIL(NCH), CAPAC(NCH), & SNOW(NCH), SWET1(NCH), RUNOFF(NCH), SMELT(NCH), & RUNSRF(NCH), FWSOIL(NCH), WETEQ1(NCH), WETINT _RL DTSTEP, SNOWM, WATADD, CAVAIL, THRUC, WRUNC, WRUNL, & TIMFRL, TIMFRC, FWETL, FWETC, THRU1, THRU2, THRUL, XTCORR, & WETFRC C**** C DATA FWET0 /0.30/ DATA FWETL /1.00/, FWETC /0.20/, TIMFRL/1.00/, TIMFRC/0.125/ C**** C**** ------------------------------------------------------------------ C**** Loop over chips: DO 100 ChNo = 1, NCH C**** C**** Add to snow cover. Melt snow if necessary. SNOW(ChNo) = SNOW(ChNo) + TSNOW(ChNo)*DTSTEP SNOWM = 0. IF( SNOW(CHNO).GT.0. .AND. TC(CHNO).GT.TF ) THEN SNOWM = MIN( SNOW(ChNo), & MAX( 0. _d 0, (TC(ChNo)-TF)*CSOIL(ChNo)/ALHM ) ) IF( SNOWM .EQ. SNOW(CHNO) ) THEN TC(ChNo) = TC(ChNo) - SNOWM * ALHM / CSOIL(ChNo) SNOW(CHNO)=0. ELSE TC(CHNO)=TF SNOW(ChNo) = SNOW(ChNo) - SNOWM ENDIF SMELT(CHNO)=SMELT(CHNO)+SNOWM/DTSTEP ENDIF C**** C**** ======================================================= C**** C**** Load interception reservoir. STEP 1: Large scale condensation. C**** C**** Determine XTCORR, the fraction of a storm that falls on a previously C**** wet surface due to the time correlation of precipitation position. C**** (Time scale TIMFRL for large scale storms set to one for FWETL=1 C**** to reflect the effective loss of "position memory" when storm C**** covers entire grid square.) XTCORR= (1.-TIMFRL) * MIN( 1. _d 0,(CAPAC(CHNO)/SATCAP(CHNO))/ $ FWETL ) C**** C**** Fill interception reservoir with precipitation. C**** THRU1 is first calculated as the amount falling through the C**** canopy under the assumption that all rain falls randomly. C**** only a fraction 1-XTCORR falls randomly, though, so the result C**** is multiplied by 1-XTCORR. C**** WATADD = TRAINL(ChNo)*DTSTEP + SMELT(CHNO)*DTSTEP CAVAIL = ( SATCAP(CHNO) - CAPAC(CHNO) ) * FWETL WETINT = CAPAC(CHNO)/SATCAP(CHNO) IF( WATADD*(1.-WETINT) .LT. CAVAIL ) THEN THRU1 = WATADD*WETINT ELSE THRU1 = (WATADD - CAVAIL) ENDIF THRU1=THRU1*(1.-XTCORR) C**** THRU2 is the amount that falls immediately through the canopy due C**** to 'position memory'. THRU2=XTCORR*WATADD THRUL=THRU1+THRU2 CAPAC(CHNO)=CAPAC(CHNO)+WATADD-THRU1-THRU2 C**** C**** --------------------------------------------------- C**** C**** STEP 2: Moist convective precipitation. C**** C**** Determine XTCORR, the fraction of a storm that falls on a previously C**** wet surface due to the time correlation of precipitation position. XTCORR= (1.-TIMFRC) * MIN( 1. _d 0,(CAPAC(CHNO)/SATCAP(CHNO))/ $ FWETC ) C**** C**** Fill interception reservoir with precipitation. C**** THRU1 is first calculated as the amount falling through the C**** canopy under the assumption that all rain falls randomly. C**** only a fraction 1-XTCORR falls randomly, though, so the result C**** is multiplied by 1-XTCORR. C**** WATADD = TRAINC(ChNo)*DTSTEP CAVAIL = ( SATCAP(CHNO) - CAPAC(CHNO) ) * FWETC WETINT = CAPAC(CHNO)/SATCAP(CHNO) IF( WATADD*(1.-WETINT) .LT. CAVAIL ) THEN THRU1 = WATADD*WETINT ELSE THRU1 = (WATADD - CAVAIL) ENDIF THRU1=THRU1*(1.-XTCORR) C**** THRU2 is the amount that falls immediately through the canopy due C**** to 'position memory'. THRU2=XTCORR*WATADD THRUC=THRU1+THRU2 CAPAC(CHNO)=CAPAC(CHNO)+WATADD-THRU1-THRU2 C**** C***** ================================================================= C**** C**** Add precipitation moisture to soil, generate runoff. if C**** temperature is below freezing, all precipitation runs off. C**** C**** STEP 1: Large scale condensation: C**** IF(SWET1(CHNO).GT.WETEQ1(CHNO) .AND. WETEQ1(CHNO).NE.1.) THEN WETFRC=(SWET1(CHNO)-WETEQ1(CHNO))/(1.-WETEQ1(CHNO)) ELSE WETFRC=0. ENDIF CAVAIL = ( 1.-WETFRC)*FWETL*WMAX(1,ITYP(ChNo))*(1-WETEQ1(CHNO)) IF ( THRUL * (1-WETFRC) .LT. CAVAIL ) THEN WRUNL = THRUL * WETFRC SWET1(ChNo) = SWET1(ChNo) * + THRUL * ( 1. - WETFRC) / WMAX(1,ITYP(ChNo)) ELSE WRUNL = THRUL - CAVAIL SWET1(CHNO) = SWET1(CHNO) + CAVAIL / WMAX(1,ITYP(ChNo)) ENDIF C**** C**** STEP 2: Moist convective precipitation: C**** IF(SWET1(CHNO).GT.WETEQ1(CHNO) .AND. WETEQ1(CHNO).NE.1.) THEN WETFRC=(SWET1(CHNO)-WETEQ1(CHNO))/(1.-WETEQ1(CHNO)) ELSE WETFRC=0. ENDIF CAVAIL = (1.-WETFRC)*FWETC*WMAX(1,ITYP(ChNo))*(1-WETEQ1(CHNO)) IF ( THRUC * (1-WETFRC) .LT. CAVAIL ) THEN WRUNC = THRUC * WETFRC SWET1(ChNo) = SWET1(ChNo) * + THRUC * ( 1. - WETFRC) / WMAX(1,ITYP(ChNo)) ELSE WRUNC = THRUC - CAVAIL SWET1(CHNO) = SWET1(CHNO) + CAVAIL / WMAX(1,ITYP(ChNo)) ENDIF C**** RUNOFF(ChNo) = RUNOFF(ChNo) + (WRUNC+WRUNL)/DTSTEP RUNSRF(ChNo) = RUNSRF(ChNo) + (WRUNC+WRUNL)/DTSTEP FWSOIL(CHNO) = FWSOIL(CHNO) + (THRUC+THRUL-WRUNC-WRUNL)/DTSTEP C**** 100 CONTINUE C**** RETURN END


C**** C**** [ END INTERC ] C**** C**** ----------------------------------------------------------------- C**** ///////////////////////////////////////////////////////////////// C**** ----------------------------------------------------------------- C**** C**** [ BEGIN RCUNST ] C**** SUBROUTINE RCUNST ( I NCH, ITYP, SUNANG, SQSCAT, PDIR, I PAR, ZLAI, GREEN, O RCUN & ) C**** C**** This subroutine calculates the unstressed canopy resistance. C**** (p. 1353, Sellers 1985.) Extinction coefficients are computed first. C**** IMPLICIT NONE C**** #include "sibber.h" C**** INTEGER NCH INTEGER ITYP(NCH), ChNo _RL SUNANG(NCH), PDIR(NCH), PAR(NCH), ZLAI(NCH), & SQSCAT(NCH), GREEN(NCH), RCUN(NCH) _RL VGCHIL(NTYPS), VGZMEW(NTYPS), & VGRST1(NTYPS), VGRST2(NTYPS), VGRST3(NTYPS) _RL RHO4, EXTK1, EXTK2, & RCINV, GAMMA, EKAT, DUM1, & DUM2, DUM3, AA, BB, & ZK, CC DATA VGCHIL / 0.1, 0.25, 0.01, -0.3, 5 0.01, 0.20, 0.0, 0.0, 9 0.0, 0.0 / DATA VGZMEW/ 0.9809, 0.9638, 0.9980, 1.0773, 5 0.9980, 0.9676, 1.000, 1.000, 9 1.000, 1.0000 / DATA VGRST1 / 2335.9, 9802.2, 2869.7, 2582.0, 5 93989.4, 9802.2, 0.0, 0.0, 9 0.0 , 0.0/ DATA VGRST2 / 0.0, 10.6, 3.7, 1.1, 5 0.01, 10.6, 0.0, 0.0, 9 0.0 , 0.0/ DATA VGRST3 / 153.5, 180.0, 233.0, 110.0, 5 855.0, 180.0, 1.0, 1.0, 9 1.0, 1.0 / DO 100 ChNo = 1, NCH C**** First compute optical parameters. C**** (Note: CHIL is constrained to be >= 0.01, as in SiB calcs.) AA = 0.5 - (0.633 + 0.330*VGCHIL(ITYP(ChNo)))*VGCHIL(ITYP(ChNo)) BB = 0.877 * ( ONE - 2.*AA ) CC = ( AA + BB*SUNANG(ChNo) ) / SUNANG(ChNo) EXTK1 = CC * SQSCAT(ChNo) EXTK2 = (ONE / VGZMEW(ITYP(ChNo))) * SQSCAT(ChNo) DUM1 = PDIR(ChNo) * CC DUM2 = (ONE-PDIR(ChNo)) * ( BB*(ONE/3.+PIE/4.) + AA*1.5 ) C**** Bound extinction coefficient by 50./ZLAI: ZK = PDIR(ChNo) *MIN( EXTK1, 50. _d 0/ZLAI(ChNo) ) + & (ONE-PDIR(ChNo))*MIN( EXTK2, 50. _d 0/ZLAI(ChNo) ) C**** Now compute unstressed canopy resistance: GAMMA = VGRST1(ITYP(ChNo)) / VGRST3(ITYP(ChNo)) + & VGRST2(ITYP(ChNo)) EKAT = EXP( ZK*ZLAI(ChNo) ) RHO4 = GAMMA / (PAR(ChNo) * (DUM1 + DUM2)) DUM1 = (VGRST2(ITYP(ChNo)) - GAMMA) / (GAMMA + 1.E-20) DUM2 = (RHO4 * EKAT + ONE) / (RHO4 + ONE) DUM3 = ZK * VGRST3(ITYP(ChNo)) RCINV = ( DUM1*LOG(DUM2) + ZK*ZLAI(ChNo) ) / DUM3 RCUN(ChNo) = ONE / (RCINV * GREEN(ChNo) + 1.E-10) 100 CONTINUE RETURN END


C**** C**** [ END RCUNST ] C**** C**** ----------------------------------------------------------------- C**** ///////////////////////////////////////////////////////////////// C**** ----------------------------------------------------------------- C**** C**** [ BEGIN SOIL ] C**** SUBROUTINE SOIL ( I NCH, ITYP, WET, VGBEEX, VGPSAX, VGCSAX, DELZ, O PHR, SOILCO, WETEQ & ) C**** C**** This subroutine returns soil moisture potential and conductivity. IMPLICIT NONE C**** #include "sibber.h" C**** INTEGER NCH INTEGER ITYP(NCH), ChNo _RL WET(NCH), PHR(NCH), SOILCO(NCH), VGPSAX(NCH), & VGCSAX(NCH), VGBEEX(NCH), DELZ(NTYPS), WETEQ(NCH), & WEXPB, WET0, PHEQ DO 100 ChNo = 1, NCH WET0 = MAX(WET(CHNO),0.01 _d 0) WEXPB = WET0**VGBEEX(ChNo) PHR(ChNo) = VGPSAX(ChNo) / WEXPB SOILCO(ChNo) = VGCSAX(ChNo) * WEXPB * WEXPB * WET0 * WET0 * WET0 PHEQ = PHR(CHNO) - DELZ(ITYP(CHNO)) WETEQ(CHNO) = ( PHEQ/VGPSAX(CHNO) ) ** ( -1/VGBEEX(CHNO) ) 100 CONTINUE RETURN END


C**** C**** [ END SOIL ] C**** C**** ----------------------------------------------------------------- C**** ///////////////////////////////////////////////////////////////// C**** ----------------------------------------------------------------- C**** C**** [ BEGIN FLUXES ] C**** SUBROUTINE FLUXES ( I NCH, ITYP, DTSTEP, ESATTC, DESDTC, ALHX, I ETURB, DEDEA, DEDTC, HSTURB, DHSDEA, DHSDTC, I RC, DRCDEA, DRCDTC, I SWNET, HLWDWN, ALWRAD, BLWRAD, ESNFRC, I TM, EM, CSOIL, PSUR, EMAXRT, WMAX, U TC, TD, EA, SWET1, SNOW, O RUNOFF, EVAP, SHFLUX, SMELT, HLWUP, BOMB, STRDG1, O STRDG2, STRDG3, STRDG4, STRDG5, STRDG6, STRDG7, O STRDG8, STRDG9 & ) C**** C**** This subroutine computes the fluxes of latent and sensible heat C**** from the surface through an energy balance calculation. C**** IMPLICIT NONE C**** #include "sibber.h" C**** INTEGER NCH INTEGER ITYP(NCH), ChNo _RL DTSTEP, ESATTC(NCH), DESDTC(NCH), ALHX(NCH), & ETURB(NCH), DEDEA(