cbl_conductivity.F90 Source File


This file depends on

sourcefile~~cbl_conductivity.f90~~EfferentGraph sourcefile~cbl_conductivity.f90 cbl_conductivity.F90 sourcefile~cbl_soilsnow_data.f90 cbl_soilsnow_data.F90 sourcefile~cbl_conductivity.f90->sourcefile~cbl_soilsnow_data.f90 sourcefile~cable_common.f90 cable_common.F90 sourcefile~cbl_soilsnow_data.f90->sourcefile~cable_common.f90 sourcefile~cable_define_types.f90 cable_define_types.F90 sourcefile~cbl_soilsnow_data.f90->sourcefile~cable_define_types.f90 sourcefile~cable_phys_constants_mod.f90 cable_phys_constants_mod.F90 sourcefile~cbl_soilsnow_data.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_climate_type_mod.f90 cable_climate_type_mod.F90 sourcefile~cable_define_types.f90->sourcefile~cable_climate_type_mod.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

Files dependent on this one

sourcefile~~cbl_conductivity.f90~~AfferentGraph sourcefile~cbl_conductivity.f90 cbl_conductivity.F90 sourcefile~cbl_gw.f90 cbl_GW.F90 sourcefile~cbl_gw.f90->sourcefile~cbl_conductivity.f90 sourcefile~cbl_stempv.f90 cbl_stempv.F90 sourcefile~cbl_stempv.f90->sourcefile~cbl_conductivity.f90 sourcefile~cbl_soilsnow_main.f90 cbl_soilsnow_main.F90 sourcefile~cbl_soilsnow_main.f90->sourcefile~cbl_stempv.f90 sourcefile~cbl_thermal.f90 cbl_thermal.F90 sourcefile~cbl_thermal.f90->sourcefile~cbl_gw.f90 sourcefile~cbl_model_driver_offline.f90 cbl_model_driver_offline.F90 sourcefile~cbl_model_driver_offline.f90->sourcefile~cbl_soilsnow_main.f90 sourcefile~cable_mpimaster.f90 cable_mpimaster.F90 sourcefile~cable_mpimaster.f90->sourcefile~cbl_model_driver_offline.f90 sourcefile~cable_mpiworker.f90 cable_mpiworker.F90 sourcefile~cable_mpiworker.f90->sourcefile~cbl_model_driver_offline.f90 sourcefile~cable_serial.f90 cable_serial.F90 sourcefile~cable_serial.f90->sourcefile~cbl_model_driver_offline.f90 sourcefile~cable_offline_driver.f90 cable_offline_driver.F90 sourcefile~cable_offline_driver.f90->sourcefile~cable_serial.f90

Source Code

MODULE total_soil_conductivity_mod

USE cbl_ssnow_data_mod

PUBLIC  total_soil_conductivity

CONTAINS

! soil thermal conductivity (incl water/ice)
FUNCTION total_soil_conductivity(ssnow,soil)

    REAL(r_2), DIMENSION(mp,ms) ::  total_soil_conductivity

    TYPE(soil_snow_type), INTENT(INOUT) :: ssnow
    TYPE(soil_parameter_type), INTENT(INOUT) :: soil

    REAL(r_2) :: exp_arg
    REAL(r_2) :: dels_r2
    REAL(r_2) :: Ko,Ktmp
    REAL(r_2), DIMENSION(mp,ms) :: Ke,quartz,Sr,Ksat,liq_frac
    REAL      :: tfreeze
    INTEGER :: k,j,i

    total_soil_conductivity(:,:) = soil%cnsd_vec(:,:)

    DO k = 1, ms
       DO j = 1, mp
          IF (soil%isoilm(j) .EQ. 9) THEN
             total_soil_conductivity(j,k) = snow_ccnsw
          ELSE
             quartz(j,k) = MAX(0.0,MIN(0.8,soil%sand_vec(j,k)*0.92))
             IF (quartz(j,k) .GT. 0.2) THEN
                Ko = 2.0
             ELSE
                Ko = 3.0
             END IF

             Ktmp      = ( (7.7**(quartz(j,k))) * &
                  (Ko**(1.0-quartz(j,k))) ) **(1.0-soil%ssat_vec(j,k))

             IF (ssnow%wb(j,k) .GE. 1.0e-15) THEN
                liq_frac(j,k) = MIN(1._r_2, MAX(0._r_2, ssnow%wbliq(j,k) / ssnow%wb(j,k)))
             ELSE
                liq_frac(j,k) = 0.0
             END IF

             Ksat(j,k) =  Ktmp * &
                  (2.2 ** (soil%ssat_vec(j,k)*(1.0-liq_frac(j,k) ) ) )*&
                  (0.57**(liq_frac(j,k)))

             Sr(j,k) = MIN( 0.9999 , &
                  MAX(0., ssnow%wb(j,k)-soil%watr(j,k))/(soil%ssat_vec(j,k)-soil%watr(j,k)) )

             !frozen or not?
             IF (Sr(j,k) .GE. 0.05) THEN
                Ke(j,k) = 0.7*LOG10(Sr(j,k)) + 1.0
             ELSE
                Ke(j,k) = 0.0
             END IF

             IF ((ssnow%wbice(j,k) .GT. 0.0) .OR. &
                  (ssnow%tgg(j,k) .LT. CTFRZ) .OR. &
                  (ssnow%isflag(j) .NE. 0) .OR.     &
                  (ssnow%snowd(j) .GE. 0.1) )   THEN

                Ke(j,k) = Sr(j,k)

             END IF

             total_soil_conductivity(j,k) = Ke(j,k)*Ksat(j,k) + &
                  (1.0-Ke(j,k))*soil%cnsd_vec(j,k)

             total_soil_conductivity(j,k) = MIN(Ksat(j,k), MAX(soil%cnsd_vec(j,k),&
                  total_soil_conductivity(j,k) ) )


          ENDIF

       END DO

    END DO

  END FUNCTION total_soil_conductivity

END MODULE total_soil_conductivity_mod