cable_driver_common.F90 Source File


This file depends on

sourcefile~~cable_driver_common.f90~~EfferentGraph sourcefile~cable_driver_common.f90 cable_driver_common.F90 sourcefile~cable_carbon.f90 cable_carbon.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_carbon.f90 sourcefile~cable_common.f90 cable_common.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_common.f90 sourcefile~cable_cru_trendy.f90 cable_cru_TRENDY.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_cru_trendy.f90 sourcefile~cable_define_types.f90 cable_define_types.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_define_types.f90 sourcefile~cable_input.f90 cable_input.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_input.f90 sourcefile~cable_iovars.f90 cable_iovars.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_iovars.f90 sourcefile~cable_luc_expt.f90 cable_LUC_EXPT.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_luc_expt.f90 sourcefile~cable_mpi.f90 cable_mpi.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_mpi.f90 sourcefile~cable_namelist_input.f90 cable_namelist_input.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_namelist_input.f90 sourcefile~cable_phys_constants_mod.f90 cable_phys_constants_mod.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_phys_constants_mod.f90 sourcefile~cable_plume_mip.f90 cable_plume_mip.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_plume_mip.f90 sourcefile~cable_site.f90 cable_site.F90 sourcefile~cable_driver_common.f90->sourcefile~cable_site.f90 sourcefile~casa_dimension.f90 casa_dimension.F90 sourcefile~cable_driver_common.f90->sourcefile~casa_dimension.f90 sourcefile~casa_ncdf.f90 casa_ncdf.F90 sourcefile~cable_driver_common.f90->sourcefile~casa_ncdf.f90 sourcefile~casa_param.f90 casa_param.F90 sourcefile~cable_driver_common.f90->sourcefile~casa_param.f90 sourcefile~casa_variable.f90 casa_variable.F90 sourcefile~cable_driver_common.f90->sourcefile~casa_variable.f90 sourcefile~pop.f90 POP.F90 sourcefile~cable_driver_common.f90->sourcefile~pop.f90 sourcefile~pop_def.f90 pop_def.F90 sourcefile~cable_driver_common.f90->sourcefile~pop_def.f90 sourcefile~pop_types.f90 pop_types.F90 sourcefile~cable_driver_common.f90->sourcefile~pop_types.f90 sourcefile~popluc.f90 POPLUC.F90 sourcefile~cable_driver_common.f90->sourcefile~popluc.f90 sourcefile~cable_carbon.f90->sourcefile~cable_common.f90 sourcefile~cable_carbon.f90->sourcefile~cable_define_types.f90 sourcefile~cable_carbon.f90->sourcefile~cable_phys_constants_mod.f90 sourcefile~cable_runtime_opts_mod.f90 cable_runtime_opts_mod.F90 sourcefile~cable_common.f90->sourcefile~cable_runtime_opts_mod.f90 sourcefile~cable_cru_trendy.f90->sourcefile~cable_define_types.f90 sourcefile~cable_cru_trendy.f90->sourcefile~cable_iovars.f90 sourcefile~cable_cru_trendy.f90->sourcefile~casa_ncdf.f90 sourcefile~cable_checks.f90 cable_checks.F90 sourcefile~cable_cru_trendy.f90->sourcefile~cable_checks.f90 sourcefile~cable_weathergenerator.f90 cable_weathergenerator.F90 sourcefile~cable_cru_trendy.f90->sourcefile~cable_weathergenerator.f90 sourcefile~cable_climate_type_mod.f90 cable_climate_type_mod.F90 sourcefile~cable_define_types.f90->sourcefile~cable_climate_type_mod.f90 sourcefile~cable_input.f90->sourcefile~cable_common.f90 sourcefile~cable_input.f90->sourcefile~cable_define_types.f90 sourcefile~cable_input.f90->sourcefile~cable_iovars.f90 sourcefile~cable_input.f90->sourcefile~cable_luc_expt.f90 sourcefile~cable_input.f90->sourcefile~casa_dimension.f90 sourcefile~cable_input.f90->sourcefile~casa_ncdf.f90 sourcefile~cable_input.f90->sourcefile~casa_param.f90 sourcefile~cable_input.f90->sourcefile~casa_variable.f90 sourcefile~cable_input.f90->sourcefile~pop.f90 sourcefile~cable_input.f90->sourcefile~pop_types.f90 sourcefile~cable_input.f90->sourcefile~popluc.f90 sourcefile~cable_abort.f90 cable_abort.F90 sourcefile~cable_input.f90->sourcefile~cable_abort.f90 sourcefile~cable_input.f90->sourcefile~cable_checks.f90 sourcefile~cable_initialise.f90 cable_initialise.F90 sourcefile~cable_input.f90->sourcefile~cable_initialise.f90 sourcefile~cable_metutils.f90 cable_metutils.F90 sourcefile~cable_input.f90->sourcefile~cable_metutils.f90 sourcefile~cable_parameters.f90 cable_parameters.F90 sourcefile~cable_input.f90->sourcefile~cable_parameters.f90 sourcefile~cable_read.f90 cable_read.F90 sourcefile~cable_input.f90->sourcefile~cable_read.f90 sourcefile~casa_inout.f90 casa_inout.F90 sourcefile~cable_input.f90->sourcefile~casa_inout.f90 sourcefile~casa_phenology.f90 casa_phenology.F90 sourcefile~cable_input.f90->sourcefile~casa_phenology.f90 sourcefile~casa_readbiome.f90 casa_readbiome.F90 sourcefile~cable_input.f90->sourcefile~casa_readbiome.f90 sourcefile~cbl_sinbet.f90 cbl_sinbet.F90 sourcefile~cable_input.f90->sourcefile~cbl_sinbet.f90 sourcefile~cable_iovars.f90->sourcefile~cable_define_types.f90 sourcefile~cable_luc_expt.f90->sourcefile~cable_common.f90 sourcefile~cable_luc_expt.f90->sourcefile~cable_define_types.f90 sourcefile~cable_luc_expt.f90->sourcefile~cable_iovars.f90 sourcefile~cable_luc_expt.f90->sourcefile~casa_ncdf.f90 sourcefile~cable_plume_mip.f90->sourcefile~cable_common.f90 sourcefile~cable_plume_mip.f90->sourcefile~cable_define_types.f90 sourcefile~cable_plume_mip.f90->sourcefile~cable_iovars.f90 sourcefile~cable_plume_mip.f90->sourcefile~casa_ncdf.f90 sourcefile~cable_plume_mip.f90->sourcefile~cable_checks.f90 sourcefile~cable_plume_mip.f90->sourcefile~cable_weathergenerator.f90 sourcefile~cable_site.f90->sourcefile~cable_common.f90 sourcefile~cable_site.f90->sourcefile~cable_iovars.f90 sourcefile~cable_site.f90->sourcefile~casa_ncdf.f90 sourcefile~casa_dimension.f90->sourcefile~cable_define_types.f90 sourcefile~casa_ncdf.f90->sourcefile~cable_common.f90 sourcefile~casa_ncdf.f90->sourcefile~cable_define_types.f90 sourcefile~casa_ncdf.f90->sourcefile~cable_iovars.f90 sourcefile~casa_param.f90->sourcefile~casa_dimension.f90 sourcefile~casa_variable.f90->sourcefile~casa_dimension.f90 sourcefile~casa_variable.f90->sourcefile~casa_param.f90 sourcefile~pop.f90->sourcefile~pop_def.f90 sourcefile~pop.f90->sourcefile~pop_types.f90 sourcefile~pop_constants.f90 pop_constants.F90 sourcefile~pop.f90->sourcefile~pop_constants.f90 sourcefile~pop_types.f90->sourcefile~pop_def.f90 sourcefile~pop_types.f90->sourcefile~pop_constants.f90 sourcefile~popluc.f90->sourcefile~cable_common.f90 sourcefile~popluc.f90->sourcefile~cable_define_types.f90 sourcefile~popluc.f90->sourcefile~cable_iovars.f90 sourcefile~popluc.f90->sourcefile~cable_luc_expt.f90 sourcefile~popluc.f90->sourcefile~casa_ncdf.f90 sourcefile~popluc.f90->sourcefile~casa_param.f90 sourcefile~popluc.f90->sourcefile~casa_variable.f90 sourcefile~popluc.f90->sourcefile~pop.f90 sourcefile~popluc.f90->sourcefile~pop_def.f90 sourcefile~popluc.f90->sourcefile~pop_types.f90 sourcefile~cable_abort.f90->sourcefile~cable_define_types.f90 sourcefile~cable_abort.f90->sourcefile~cable_iovars.f90 sourcefile~cable_checks.f90->sourcefile~cable_common.f90 sourcefile~cable_checks.f90->sourcefile~cable_define_types.f90 sourcefile~cable_checks.f90->sourcefile~cable_iovars.f90 sourcefile~cable_checks.f90->sourcefile~cable_abort.f90 sourcefile~cable_climate_type_mod.f90->sourcefile~cable_common.f90 sourcefile~grid_constants_cbl.f90 grid_constants_cbl.F90 sourcefile~cable_climate_type_mod.f90->sourcefile~grid_constants_cbl.f90 sourcefile~cable_initialise.f90->sourcefile~cable_common.f90 sourcefile~cable_initialise.f90->sourcefile~cable_define_types.f90 sourcefile~cable_initialise.f90->sourcefile~cable_iovars.f90 sourcefile~cable_initialise.f90->sourcefile~cable_abort.f90 sourcefile~cable_initialise.f90->sourcefile~cable_read.f90 sourcefile~cable_parameters.f90->sourcefile~cable_common.f90 sourcefile~cable_parameters.f90->sourcefile~cable_define_types.f90 sourcefile~cable_parameters.f90->sourcefile~cable_iovars.f90 sourcefile~cable_parameters.f90->sourcefile~cable_luc_expt.f90 sourcefile~cable_parameters.f90->sourcefile~cable_phys_constants_mod.f90 sourcefile~cable_parameters.f90->sourcefile~casa_dimension.f90 sourcefile~cable_parameters.f90->sourcefile~casa_param.f90 sourcefile~cable_parameters.f90->sourcefile~casa_variable.f90 sourcefile~cable_parameters.f90->sourcefile~cable_abort.f90 sourcefile~cable_parameters.f90->sourcefile~casa_phenology.f90 sourcefile~cable_pft_params.f90 cable_pft_params.F90 sourcefile~cable_parameters.f90->sourcefile~cable_pft_params.f90 sourcefile~cable_soil_params.f90 cable_soil_params.F90 sourcefile~cable_parameters.f90->sourcefile~cable_soil_params.f90 sourcefile~cable_surface_types.f90 cable_surface_types.F90 sourcefile~cable_parameters.f90->sourcefile~cable_surface_types.f90 sourcefile~cable_parameters.f90->sourcefile~grid_constants_cbl.f90 sourcefile~cable_read.f90->sourcefile~cable_define_types.f90 sourcefile~cable_read.f90->sourcefile~cable_iovars.f90 sourcefile~cable_read.f90->sourcefile~cable_abort.f90 sourcefile~casa_inout.f90->sourcefile~cable_common.f90 sourcefile~casa_inout.f90->sourcefile~cable_define_types.f90 sourcefile~casa_inout.f90->sourcefile~cable_iovars.f90 sourcefile~casa_inout.f90->sourcefile~casa_dimension.f90 sourcefile~casa_inout.f90->sourcefile~casa_param.f90 sourcefile~casa_inout.f90->sourcefile~casa_variable.f90 sourcefile~casa_inout.f90->sourcefile~casa_phenology.f90 sourcefile~casa_offline_inout.f90 casa_offline_inout.F90 sourcefile~casa_inout.f90->sourcefile~casa_offline_inout.f90 sourcefile~casa_phenology.f90->sourcefile~casa_dimension.f90 sourcefile~casa_readbiome.f90->sourcefile~cable_common.f90 sourcefile~casa_readbiome.f90->sourcefile~cable_define_types.f90 sourcefile~casa_readbiome.f90->sourcefile~casa_dimension.f90 sourcefile~casa_readbiome.f90->sourcefile~casa_param.f90 sourcefile~casa_readbiome.f90->sourcefile~casa_variable.f90 sourcefile~casa_readbiome.f90->sourcefile~casa_phenology.f90 sourcefile~cable_maths_constants_mod.f90 cable_maths_constants_mod.F90 sourcefile~cbl_sinbet.f90->sourcefile~cable_maths_constants_mod.f90 sourcefile~pop_constants.f90->sourcefile~pop_def.f90 sourcefile~cable_pft_params.f90->sourcefile~cable_define_types.f90 sourcefile~cable_pft_params.f90->sourcefile~grid_constants_cbl.f90 sourcefile~cable_soil_params.f90->sourcefile~cable_define_types.f90 sourcefile~cable_soil_params.f90->sourcefile~grid_constants_cbl.f90 sourcefile~casa_offline_inout.f90->sourcefile~cable_common.f90 sourcefile~casa_offline_inout.f90->sourcefile~cable_define_types.f90 sourcefile~casa_offline_inout.f90->sourcefile~casa_ncdf.f90 sourcefile~casa_offline_inout.f90->sourcefile~casa_variable.f90 sourcefile~casa_offline_inout.f90->sourcefile~casa_phenology.f90

Files dependent on this one

sourcefile~~cable_driver_common.f90~~AfferentGraph sourcefile~cable_driver_common.f90 cable_driver_common.F90 sourcefile~cable_mpimaster.f90 cable_mpimaster.F90 sourcefile~cable_mpimaster.f90->sourcefile~cable_driver_common.f90 sourcefile~cable_mpiworker.f90 cable_mpiworker.F90 sourcefile~cable_mpiworker.f90->sourcefile~cable_driver_common.f90 sourcefile~cable_offline_driver.f90 cable_offline_driver.F90 sourcefile~cable_offline_driver.f90->sourcefile~cable_driver_common.f90 sourcefile~cable_serial.f90 cable_serial.F90 sourcefile~cable_offline_driver.f90->sourcefile~cable_serial.f90 sourcefile~cable_serial.f90->sourcefile~cable_driver_common.f90

Source Code

! CSIRO Open Source Software License Agreement (variation of the BSD / MIT License)
! Copyright (c) 2015, Commonwealth Scientific and Industrial Research Organisation 
! (CSIRO) ABN 41 687 119 230.

MODULE cable_driver_common_mod
  !! Module for CABLE offline driver common routines.
  USE cable_common_module, ONLY : &
    filename,                     &
    calcsoilalbedo,               &
    redistrb,                     &
    wiltParam,                    &
    satuParam,                    &
    cable_user,                   &
    gw_params,                    &
    cable_runtime
  USE cable_IO_vars_module, ONLY : &
    soilparmnew,                   &
    output,                        &
    patchout,                      &
    check,                         &
    verbose,                       &
    leaps,                         &
    logn,                          &
    fixedCO2,                      &
    ncciy,                         &
    gswpfile,                      &
    globalMetfile,                 &
    set_group_output_values,       &
    timeunits,                     &
    exists,                        &
    calendar
  USE casadimension, ONLY : icycle
  USE casavariable, ONLY : casafile
  USE cable_namelist_util, ONLY : &
    get_namelist_file_name,       &
    CABLE_NAMELIST,               &
    arg_not_namelist
  USE cable_mpi_mod, ONLY : mpi_grp_t
  USE cable_phys_constants_mod, ONLY : CTFRZ => TFRZ
  USE cable_input_module, ONLY : open_met_file
  USE CABLE_PLUME_MIP, ONLY : PLUME_MIP_TYPE, PLUME_MIP_INIT
  USE CABLE_CRU, ONLY : CRU_TYPE, CRU_INIT
  USE CABLE_site, ONLY : site_TYPE, site_INIT
  IMPLICIT NONE
  PRIVATE

  INTEGER, PARAMETER :: CASAONLY_ICYCLE_MIN = 10
  INTEGER, PARAMETER :: N_MET_FORCING_VARIABLES_GSWP = 8
    !! Number of GSWP met forcing variables (rain, snow, lw, sw, ps, qa, ta, wd)

  LOGICAL, SAVE, PUBLIC :: vegparmnew    = .FALSE. ! using new format input file (BP dec 2007)
  LOGICAL, SAVE, PUBLIC :: spinup        = .FALSE. ! model spinup to soil state equilibrium?
  LOGICAL, SAVE, PUBLIC :: spincasa      = .FALSE. ! TRUE: CASA-CNP Will spin mloop times, FALSE: no spin up
  LOGICAL, SAVE, PUBLIC :: CASAONLY      = .FALSE. ! ONLY Run CASA-CNP
  LOGICAL, SAVE, PUBLIC :: l_casacnp     = .FALSE. ! using CASA-CNP with CABLE
  LOGICAL, SAVE, PUBLIC :: l_landuse     = .FALSE. ! using CASA-CNP with CABLE
  LOGICAL, SAVE, PUBLIC :: l_laiFeedbk   = .FALSE. ! using prognostic LAI
  LOGICAL, SAVE, PUBLIC :: l_vcmaxFeedbk = .FALSE. ! using prognostic Vcmax

  REAL, SAVE, PUBLIC :: delsoilM ! allowed variation in soil moisture for spin up
  REAL, SAVE, PUBLIC :: delsoilT ! allowed variation in soil temperature for spin up
  REAL, SAVE, PUBLIC :: delgwM = 1e-4

  INTEGER, SAVE, PUBLIC :: LALLOC = 0 ! allocation coefficient for passing to spincasa

  NAMELIST /CABLE/  &
    filename,       & ! TYPE, containing input filenames
    vegparmnew,     & ! use new soil param. method
    soilparmnew,    & ! use new soil param. method
    calcsoilalbedo, & ! albedo considers soil color Ticket #27
    spinup,         & ! spinup model (soil) to steady state
    delsoilM,       &
    delsoilT,       &
    delgwM,         &
    output,         &
    patchout,       &
    check,          &
    verbose,        &
    leaps,          &
    logn,           &
    fixedCO2,       &
    spincasa,       &
    l_casacnp,      &
    l_landuse,      &
    l_laiFeedbk,    &
    l_vcmaxFeedbk,  &
    CASAONLY,       &
    icycle,         &
    casafile,       &
    ncciy,          &
    gswpfile,       &
    globalMetfile,  &
    redistrb,       &
    wiltParam,      &
    satuParam,      &
    cable_user,     & ! additional USER switches
    gw_params

  PUBLIC :: cable_driver_init
  PUBLIC :: cable_driver_init_gswp
  PUBLIC :: cable_driver_init_plume
  PUBLIC :: cable_driver_init_cru
  PUBLIC :: cable_driver_init_site
  PUBLIC :: cable_driver_init_default
  PUBLIC :: prepareFiles
  PUBLIC :: renameFiles
  PUBLIC :: LUCdriver

CONTAINS

  SUBROUTINE cable_driver_init(mpi_grp, trunk_sumbal, NRRRR)
    !! Model initialisation routine for the CABLE offline driver.
    TYPE(mpi_grp_t), INTENT(IN) :: mpi_grp !! MPI group to use
    DOUBLE PRECISION, INTENT(OUT) :: trunk_sumbal
      !! Reference value for quasi-bitwise reproducibility checks.
    INTEGER, INTENT(OUT) :: NRRRR !! Number of repeated spin-up cycles

    INTEGER :: ioerror, unit
    CHARACTER(len=4) :: cRank ! for worker-logfiles

    !check to see if first argument passed to cable is
    !the name of the namelist file
    !if not use cable.nml
    CALL get_namelist_file_name()

    IF (mpi_grp%rank == 0) THEN
      WRITE(*,*) "THE NAME LIST IS ", CABLE_NAMELIST
    END IF

    ! Open, read and close the namelist file.
    OPEN(NEWUNIT=unit, FILE=CABLE_NAMELIST, STATUS="OLD", ACTION="READ")
    READ(unit, NML=CABLE)
    CLOSE(unit)

    cable_runtime%offline = .TRUE.

    ! Open, read and close the consistency check file.
    ! Check triggered by cable_user%consistency_check = .TRUE. in cable.nml
    IF (mpi_grp%rank == 0 .AND. cable_user%consistency_check) THEN
      OPEN(NEWUNIT=unit, FILE=filename%trunk_sumbal, STATUS='old', ACTION='READ', IOSTAT=ioerror)
      IF(ioerror == 0) THEN
        READ(unit, *) trunk_sumbal  ! written by previous trunk version
      END IF
      CLOSE(unit)
    END IF

    ! Open log file:
    IF (mpi_grp%rank == 0) THEN
      OPEN(logn, FILE=filename%log)
    ELSE IF (cable_user%logworker) THEN
      WRITE(cRank, FMT='(I4.4)') mpi_grp%rank
      OPEN(NEWUNIT=logn, FILE="cable_log_"//cRank, STATUS="REPLACE")
    ELSE
      OPEN(NEWUNIT=logn, FILE="/dev/null")
    END IF

    IF (IARGC() > 0 .AND. arg_not_namelist) THEN
      CALL GETARG(1, filename%met)
      CALL GETARG(2, casafile%cnpipool)
    END IF

    ! Initialise flags to output individual variables according to group
    ! options from the namelist file
    IF (mpi_grp%rank == 0) THEN
      CALL set_group_output_values()
    END IF

    IF (TRIM(cable_user%POPLUC_RunType) == 'static') THEN
      cable_user%POPLUC= .FALSE.
    END IF

    ! TODO(Sean): we should not be setting namelist parameters in the following if
    ! block - all options are all configurable via the namelist file and is
    ! unclear that these options are being overwritten. A better approach would be
    ! to error for bad combinations of namelist parameters.
    IF (icycle > CASAONLY_ICYCLE_MIN) THEN
      icycle                     = icycle - CASAONLY_ICYCLE_MIN
      CASAONLY                   = .TRUE.
      CABLE_USER%CASA_DUMP_READ  = .TRUE.
      CABLE_USER%CASA_DUMP_WRITE = .FALSE.
    ELSE IF (icycle == 0) THEN
      CABLE_USER%CASA_DUMP_READ  = .FALSE.
      spincasa                   = .FALSE.
      CABLE_USER%CALL_POP        = .FALSE.
    END IF

    ! TODO(Sean): overwriting l_casacnp defeats the purpose of it being a namelist
    ! option - we should either deprecate the l_casacnp option or not overwrite
    ! its value.
    l_casacnp = icycle > 0

    IF (l_casacnp .AND. (icycle == 0 .OR. icycle > 3)) THEN
      STOP 'icycle must be 1 to 3 when using casaCNP'
    END IF
    IF ((l_laiFeedbk .OR. l_vcmaxFeedbk) .AND. (.NOT. l_casacnp)) THEN
      STOP 'casaCNP required to get prognostic LAI or Vcmax'
    END IF
    IF (l_vcmaxFeedbk .AND. (icycle < 2 .OR. icycle > 3)) THEN
      STOP 'icycle must be 2 to 3 to get prognostic Vcmax'
    END IF
    IF (icycle > 0 .AND. (.NOT. soilparmnew)) THEN
      STOP 'casaCNP must use new soil parameters'
    END IF

    ! vh_js ! suggest LALLOC should ulitmately be a switch in the .nml file
    IF (cable_user%CALL_POP) THEN
      LALLOC = 3 ! for use with POP: makes use of pipe model to partition between stem and leaf
    END IF

    NRRRR = MERGE(MAX(cable_user%CASA_NREP,1), 1, CASAONLY)

  END SUBROUTINE cable_driver_init

  SUBROUTINE cable_driver_init_gswp(mpi_grp, GSWP_MID, NRRRR)
    !! Model initialisation routine (GSWP specific).
    TYPE(mpi_grp_t), INTENT(IN) :: mpi_grp !! MPI group to use
    INTEGER, ALLOCATABLE, INTENT(OUT), OPTIONAL :: GSWP_MID(:,:) !! NetCDF file IDs for GSWP met forcing
    INTEGER, INTENT(IN), OPTIONAL :: NRRRR !! Number of repeated spin-up cycles

    IF (cable_user%YearStart == 0) THEN
      IF (ncciy == 0) THEN
        IF (mpi_grp%rank == 0) THEN
          PRINT*, 'undefined start year for gswp met: '
          PRINT*, 'enter value for ncciy or'
          PRINT*, '(CABLE_USER%YearStart and  CABLE_USER%YearEnd) in cable.nml'
        END IF
        WRITE(logn,*) 'undefined start year for gswp met: '
        WRITE(logn,*) 'enter value for ncciy or'
        WRITE(logn,*) '(CABLE_USER%YearStart and  CABLE_USER%YearEnd) in cable.nml'
        STOP
      END IF
      cable_user%YearStart = ncciy
      cable_user%YearEnd = ncciy
    END IF

    IF (.NOT. (PRESENT(GSWP_MID) .AND. PRESENT(NRRRR))) RETURN

    IF (NRRRR > 1 .AND. (.NOT. ALLOCATED(GSWP_MID))) THEN
      ALLOCATE(GSWP_MID(N_MET_FORCING_VARIABLES_GSWP, cable_user%YearStart:cable_user%YearEnd))
    END IF

  END SUBROUTINE cable_driver_init_gswp

  SUBROUTINE cable_driver_init_site(site)
    !* Model initialisation routine (site met specific).
    ! Site experiment, e.g. AmazonFace (spinup or transient run type).
    TYPE (site_TYPE), INTENT(OUT) :: site

    CHARACTER(len=9) :: str1, str2, str3

    IF (.NOT. l_casacnp) THEN
      WRITE(*,*) "MetType=site only works with CASA-CNP turned on"
      STOP 991
    END IF

    CALL site_INIT( site )
    WRITE(str1,'(i4)') cable_user%YearStart
    str1 = ADJUSTL(str1)
    WRITE(str2,'(i2)') 1
    str2 = ADJUSTL(str2)
    WRITE(str3,'(i2)') 1
    str3 = ADJUSTL(str3)
    timeunits="seconds since "//TRIM(str1)//"-"//TRIM(str2)//"-"//TRIM(str3)//"00:00"
    calendar = 'standard'

  END SUBROUTINE cable_driver_init_site

  SUBROUTINE cable_driver_init_default(dels, koffset, kend)
    !! Model initialisation routine (default met specific).
    REAL, INTENT(OUT) :: dels !! Time step size in seconds
    INTEGER, INTENT(OUT) :: koffset !! Timestep to start at
    INTEGER, INTENT(OUT) :: kend !! No. of time steps in run

    ! Open met data and get site information from netcdf file.
    ! This retrieves time step size, number of timesteps, starting date,
    ! latitudes, longitudes, number of sites.
    CALL open_met_file(dels, koffset, kend, spinup, CTFRZ)
    IF (koffset /= 0 .AND. cable_user%CALL_POP) THEN
      WRITE(*,*) "When using POP, episode must start at Jan 1st!"
      STOP 991
    END IF

  END SUBROUTINE cable_driver_init_default

  SUBROUTINE cable_driver_init_plume(dels, koffset, PLUME)
    !* Model initialisation routine (PLUME specific).
    ! PLUME experiment setup using WATCH.
    REAL, INTENT(OUT) :: dels !! Time step size in seconds
    INTEGER, INTENT(OUT) :: koffset !! Timestep to start at
    TYPE(PLUME_MIP_TYPE), INTENT(OUT) :: PLUME

    CHARACTER(len=9) :: str1, str2, str3

    CALL PLUME_MIP_INIT(PLUME)
    dels = PLUME%dt
    koffset = 0
    leaps = PLUME%LeapYears
    WRITE(str1,'(i4)') cable_user%YearStart
    str1 = ADJUSTL(str1)
    WRITE(str2,'(i2)') 1
    str2 = ADJUSTL(str2)
    WRITE(str3,'(i2)') 1
    str3 = ADJUSTL(str3)
    timeunits="seconds since "//TRIM(str1)//"-"//TRIM(str2)//"-"//TRIM(str3)//"00:00"

  END SUBROUTINE cable_driver_init_plume

  SUBROUTINE cable_driver_init_cru(dels, koffset, CRU)
    !* Model initialisation routine (CRU specific).
    ! TRENDY experiment using CRU-NCEP.
    REAL, INTENT(OUT) :: dels !! Time step size in seconds
    INTEGER, INTENT(OUT) :: koffset !! Timestep to start at
    TYPE(CRU_TYPE), INTENT(OUT) :: CRU

    CHARACTER(len=9) :: str1, str2, str3

    CALL CRU_INIT(CRU)
    dels = CRU%dtsecs
    koffset = 0
    leaps = .FALSE. ! No leap years in CRU-NCEP
    exists%Snowf = .FALSE.
      ! No snow in CRU-NCEP, so ensure it will be determined from temperature
      ! in CABLE
    WRITE(str1,'(i4)') cable_user%YearStart
    str1 = ADJUSTL(str1)
    WRITE(str2,'(i2)') 1
    str2 = ADJUSTL(str2)
    WRITE(str3,'(i2)') 1
    str3 = ADJUSTL(str3)
    timeunits="seconds since "//TRIM(str1)//"-"//TRIM(str2)//"-"//TRIM(str3)//"00:00"

  END SUBROUTINE cable_driver_init_cru

  SUBROUTINE prepareFiles(ncciy)
    !* Select the correct files given the year for filenames following the gswp format
    
    USE cable_IO_vars_module, ONLY: logn,gswpfile
    IMPLICIT NONE
    INTEGER, INTENT(IN) :: ncciy !! Year to select met. forcing data.

    WRITE(logn,*) 'CABLE offline global run using gswp forcing for ', ncciy
    PRINT *,      'CABLE offline global run using gswp forcing for ', ncciy

    CALL renameFiles(logn,gswpfile%rainf,ncciy,'rainf')
    CALL renameFiles(logn,gswpfile%snowf,ncciy,'snowf')
    CALL renameFiles(logn,gswpfile%LWdown,ncciy,'LWdown')
    CALL renameFiles(logn,gswpfile%SWdown,ncciy,'SWdown')
    CALL renameFiles(logn,gswpfile%PSurf,ncciy,'PSurf')
    CALL renameFiles(logn,gswpfile%Qair,ncciy,'Qair')
    CALL renameFiles(logn,gswpfile%Tair,ncciy,'Tair')
    CALL renameFiles(logn,gswpfile%wind,ncciy,'wind')

  END SUBROUTINE prepareFiles

  SUBROUTINE renameFiles(logn,inFile,ncciy,inName)
    !! Replace the year in the filename with the value of ncciy.

    IMPLICIT NONE
    INTEGER, INTENT(IN) :: logn !! Log file unit number
    INTEGER, INTENT(IN) :: ncciy !! Year to use in replacement in filenames
    INTEGER:: nn
    CHARACTER(LEN=200), INTENT(INOUT) :: inFile
    CHARACTER(LEN=*),  INTENT(IN)    :: inName
    INTEGER :: idummy

    nn = INDEX(inFile,'19')
    READ(inFile(nn:nn+3),'(i4)') idummy
    WRITE(inFile(nn:nn+3),'(i4.4)') ncciy
    WRITE(logn,*) TRIM(inName), ' global data from ', TRIM(inFile)

  END SUBROUTINE renameFiles

  !==============================================================================
  ! subroutine for 
  SUBROUTINE LUCdriver( casabiome,casapool, &
    casaflux,POP,LUC_EXPT, POPLUC, veg )
      !* Reading LU input data, zeroing biomass in empty secondary forest tiles
      ! and tranferring LUC-based age weights for secondary forest to POP structure
    USE cable_def_types_mod , ONLY: veg_parameter_type, mland
    USE cable_carbon_module
    USE cable_common_module, ONLY: CABLE_USER, CurYear
    USE casa_ncdf_module, ONLY: is_casa_time
    USE cable_IO_vars_module, ONLY: logn, landpt, patch
    USE casadimension
    USE casaparm
    USE casavariable
    USE POP_Types,  ONLY: POP_TYPE
    USE POPMODULE,            ONLY: POPStep, POP_init_single
    USE TypeDef,              ONLY: i4b, dp
    USE CABLE_LUC_EXPT, ONLY: LUC_EXPT_TYPE, read_LUH2,&
      ptos,ptog,stog,gtos,grassfrac, pharv, smharv, syharv
    USE POPLUC_Types
    USE POPLUC_Module, ONLY: POPLUCStep, POPLUC_weights_Transfer, WRITE_LUC_OUTPUT_NC, &
      POP_LUC_CASA_transfer,  WRITE_LUC_RESTART_NC, READ_LUC_RESTART_NC

    IMPLICIT NONE

    TYPE (casa_biome),            INTENT(INOUT) :: casabiome
    TYPE (casa_pool),             INTENT(INOUT) :: casapool
    TYPE (casa_flux),             INTENT(INOUT) :: casaflux
    TYPE (POP_TYPE), INTENT(INOUT)     :: POP
    TYPE (LUC_EXPT_TYPE), INTENT(INOUT) :: LUC_EXPT
    TYPE(POPLUC_TYPE), INTENT(INOUT) :: POPLUC
    TYPE (veg_parameter_type),    INTENT(IN) :: veg  ! vegetation parameters

    INTEGER ::  k, j, l, yyyy

    WRITE(*,*) 'cablecasa_LUC', CurYear
    yyyy = CurYear

    LUC_EXPT%CTSTEP = yyyy -  LUC_EXPT%FirstYear + 1

    CALL READ_LUH2(LUC_EXPT)

    DO k=1,mland
      POPLUC%ptos(k) = LUC_EXPT%INPUT(ptos)%VAL(k)
      POPLUC%ptog(k) = LUC_EXPT%INPUT(ptog)%VAL(k)
      POPLUC%stop(k) = 0.0
      POPLUC%stog(k) = LUC_EXPT%INPUT(stog)%VAL(k)
      POPLUC%gtop(k) = 0.0
      POPLUC%gtos(k) = LUC_EXPT%INPUT(gtos)%VAL(k)
      POPLUC%pharv(k) = LUC_EXPT%INPUT(pharv)%VAL(k)
      POPLUC%smharv(k) = LUC_EXPT%INPUT(smharv)%VAL(k)
      POPLUC%syharv(k) = LUC_EXPT%INPUT(syharv)%VAL(k)
      POPLUC%thisyear = yyyy
    ENDDO

    ! zero secondary forest tiles in POP where secondary forest area is zero
    DO k=1,mland
      IF ((POPLUC%frac_primf(k)-POPLUC%frac_forest(k))==0.0 &
           .AND. (.NOT.LUC_EXPT%prim_only(k))) THEN
        j = landpt(k)%cstart+1
        DO l=1,SIZE(POP%Iwood)
          IF( POP%Iwood(l) == j) THEN
            CALL POP_init_single(POP,veg%disturbance_interval,l)
            EXIT
          ENDIF
        ENDDO

        casapool%cplant(j,leaf) = 0.01
        casapool%nplant(j,leaf)= casabiome%ratioNCplantmin(veg%iveg(j),leaf)* casapool%cplant(j,leaf)
        casapool%pplant(j,leaf)= casabiome%ratioPCplantmin(veg%iveg(j),leaf)* casapool%cplant(j,leaf)

        casapool%cplant(j,froot) = 0.01
        casapool%nplant(j,froot)= casabiome%ratioNCplantmin(veg%iveg(j),froot)* casapool%cplant(j,froot)
        casapool%pplant(j,froot)= casabiome%ratioPCplantmin(veg%iveg(j),froot)* casapool%cplant(j,froot)

        casapool%cplant(j,wood) = 0.01
        casapool%nplant(j,wood)= casabiome%ratioNCplantmin(veg%iveg(j),wood)* casapool%cplant(j,wood)
        casapool%pplant(j,wood)= casabiome%ratioPCplantmin(veg%iveg(j),wood)* casapool%cplant(j,wood)
        casaflux%frac_sapwood(j) = 1.0

      ENDIF
    ENDDO

    CALL POPLUCStep(POPLUC,yyyy)

    CALL POPLUC_weights_transfer(POPLUC,POP,LUC_EXPT)

  END SUBROUTINE LUCdriver

END MODULE cable_driver_common_mod