Calculate_kr_Durner_Base Module Function

module function Calculate_kr_Durner_Base(alpha1, n1, m1, w1, alpha2, n2, m2, w2, l, h) result(kr)

Arguments

Type IntentOptional Attributes Name
real(kind=real64), intent(in) :: alpha1
real(kind=real64), intent(in) :: n1
real(kind=real64), intent(in) :: m1
real(kind=real64), intent(in) :: w1
real(kind=real64), intent(in) :: alpha2
real(kind=real64), intent(in) :: n2
real(kind=real64), intent(in) :: m2
real(kind=real64), intent(in) :: w2
real(kind=real64), intent(in) :: l
real(kind=real64), intent(in) :: h

Return Value real(kind=real64)


Called by

proc~~calculate_kr_durner_base~~CalledByGraph proc~calculate_kr_durner_base Calculate_kr_Durner_Base interface~calculate_kr_durner_base Calculate_kr_Durner_Base interface~calculate_kr_durner_base->proc~calculate_kr_durner_base proc~calculate_kr_base_durner Calculate_kr_Base_Durner proc~calculate_kr_base_durner->interface~calculate_kr_durner_base proc~calculate_kr_base_impedance_durner Calculate_kr_Base_Impedance_Durner proc~calculate_kr_base_impedance_durner->interface~calculate_kr_durner_base proc~calculate_kr_base_impedance_viscosity_durner Calculate_kr_Base_Impedance_Viscosity_Durner proc~calculate_kr_base_impedance_viscosity_durner->interface~calculate_kr_durner_base proc~calculate_kr_base_viscosity_durner Calculate_kr_Base_Viscosity_Durner proc~calculate_kr_base_viscosity_durner->interface~calculate_kr_durner_base interface~calculate_kr_base_durner Type_HCF_Base_Durner%Calculate_kr_Base_Durner interface~calculate_kr_base_durner->proc~calculate_kr_base_durner interface~calculate_kr_base_impedance_durner Type_HCF_Base_Impedance_Durner%Calculate_kr_Base_Impedance_Durner interface~calculate_kr_base_impedance_durner->proc~calculate_kr_base_impedance_durner interface~calculate_kr_base_impedance_viscosity_durner Type_HCF_Base_Impedance_Viscosity_Durner%Calculate_kr_Base_Impedance_Viscosity_Durner interface~calculate_kr_base_impedance_viscosity_durner->proc~calculate_kr_base_impedance_viscosity_durner interface~calculate_kr_base_viscosity_durner Type_HCF_Base_Viscosity_Durner%Calculate_kr_Base_Viscosity_Durner interface~calculate_kr_base_viscosity_durner->proc~calculate_kr_base_viscosity_durner proc~calculate_kflh_base_durner Calculate_Kflh_Base_Durner proc~calculate_kflh_base_durner->interface~calculate_kr_base_durner proc~calculate_kflh_base_impedance_durner Calculate_Kflh_Base_Impedance_Durner proc~calculate_kflh_base_impedance_durner->interface~calculate_kr_base_impedance_durner proc~calculate_kflh_base_impedance_viscosity_durner Calculate_Kflh_Base_Impedance_Viscosity_Durner proc~calculate_kflh_base_impedance_viscosity_durner->interface~calculate_kr_base_impedance_viscosity_durner proc~calculate_kflh_base_viscosity_durner Calculate_Kflh_Base_Viscosity_Durner proc~calculate_kflh_base_viscosity_durner->interface~calculate_kr_base_viscosity_durner interface~calculate_kflh_base_durner Type_HCF_Base_Durner%Calculate_Kflh_Base_Durner interface~calculate_kflh_base_durner->proc~calculate_kflh_base_durner interface~calculate_kflh_base_impedance_durner Type_HCF_Base_Impedance_Durner%Calculate_Kflh_Base_Impedance_Durner interface~calculate_kflh_base_impedance_durner->proc~calculate_kflh_base_impedance_durner interface~calculate_kflh_base_impedance_viscosity_durner Type_HCF_Base_Impedance_Viscosity_Durner%Calculate_Kflh_Base_Impedance_Viscosity_Durner interface~calculate_kflh_base_impedance_viscosity_durner->proc~calculate_kflh_base_impedance_viscosity_durner interface~calculate_kflh_base_viscosity_durner Type_HCF_Base_Viscosity_Durner%Calculate_Kflh_Base_Viscosity_Durner interface~calculate_kflh_base_viscosity_durner->proc~calculate_kflh_base_viscosity_durner proc~update_kflh_base_durner Update_Kflh_Base_Durner proc~update_kflh_base_durner->interface~calculate_kflh_base_durner proc~update_kflh_base_impedance_durner Update_Kflh_Base_Impedance_Durner proc~update_kflh_base_impedance_durner->interface~calculate_kflh_base_impedance_durner proc~update_kflh_base_impedance_viscosity_durner Update_Kflh_Base_Impedance_Viscosity_Durner proc~update_kflh_base_impedance_viscosity_durner->interface~calculate_kflh_base_impedance_viscosity_durner proc~update_kflh_base_viscosity_durner Update_Kflh_Base_Viscosity_Durner proc~update_kflh_base_viscosity_durner->interface~calculate_kflh_base_viscosity_durner interface~update_kflh_base_durner Type_HCF_Base_Durner%Update_Kflh_Base_Durner interface~update_kflh_base_durner->proc~update_kflh_base_durner interface~update_kflh_base_impedance_durner Type_HCF_Base_Impedance_Durner%Update_Kflh_Base_Impedance_Durner interface~update_kflh_base_impedance_durner->proc~update_kflh_base_impedance_durner interface~update_kflh_base_impedance_viscosity_durner Type_HCF_Base_Impedance_Viscosity_Durner%Update_Kflh_Base_Impedance_Viscosity_Durner interface~update_kflh_base_impedance_viscosity_durner->proc~update_kflh_base_impedance_viscosity_durner interface~update_kflh_base_viscosity_durner Type_HCF_Base_Viscosity_Durner%Update_Kflh_Base_Viscosity_Durner interface~update_kflh_base_viscosity_durner->proc~update_kflh_base_viscosity_durner

Source Code

    module function Calculate_kr_Durner_Base(alpha1, n1, m1, w1, alpha2, n2, m2, w2, l, h) result(kr)
        !$omp declare simd uniform(alpha1, n1, m1, w1, alpha2, n2, m2, w2, l, h)
        implicit none
        real(real64), intent(in) :: alpha1, alpha2
        real(real64), intent(in) :: n1, n2
        real(real64), intent(in) :: m1, m2
        real(real64), intent(in) :: w1, w2
        real(real64), intent(in) :: l
        real(real64), intent(in) :: h
        real(real64) :: kr
        real(real64) :: Sw1, Sw2

        if (h < 0.0d0) then
            Sw1 = (1.0d0 + (-alpha1 * h)**n1)**(-m1)
            Sw2 = (1.0d0 + (-alpha2 * h)**n2)**(-m2)
            kr = (w1 * Sw1 + w2 * Sw2)**l * &
                 (w1 * alpha1 * (1.0d0 - (1.0d0 - Sw1**(1.0d0 / m1))**m1) &
                  + w2 * alpha2 * (1.0d0 - (1.0d0 - Sw2**(1.0d0 / m2))**m2))**2.0d0 / &
                 (w1 * alpha1 + w2 * alpha2)**2.0d0
        else
            kr = 1.0d0
        end if

    end function Calculate_kr_Durner_Base