m_modmet_fpsim.f90 Source File


This file depends on

sourcefile~~m_modmet_fpsim.f90~~EfferentGraph sourcefile~m_modmet_fpsim.f90 m_modmet_fpsim.f90 sourcefile~modmet_constants.f90 modmet_constants.f90 sourcefile~m_modmet_fpsim.f90->sourcefile~modmet_constants.f90

Files dependent on this one

sourcefile~~m_modmet_fpsim.f90~~AfferentGraph sourcefile~m_modmet_fpsim.f90 m_modmet_fpsim.f90 sourcefile~m_modmet_flxln2.f90 m_modmet_flxln2.f90 sourcefile~m_modmet_flxln2.f90->sourcefile~m_modmet_fpsim.f90 sourcefile~m_modnet_z0corr.f90 m_modnet_z0corr.f90 sourcefile~m_modnet_z0corr.f90->sourcefile~m_modmet_fpsim.f90 sourcefile~modmet.f90 modmet.f90 sourcefile~modmet.f90->sourcefile~m_modmet_fpsim.f90 sourcefile~modmet.f90->sourcefile~m_modmet_flxln2.f90 sourcefile~m_modmet_lusthov.f90 m_modmet_lusthov.f90 sourcefile~modmet.f90->sourcefile~m_modmet_lusthov.f90 sourcefile~m_modmet_lusthov.f90->sourcefile~m_modmet_flxln2.f90

Source Code

!------------------------------------------------------------------------------
! Module:     m_modmet_fpsim
! Authors:    Marte Voorneveld, RIVM,
!             Anton Beljaars, KNMI
!             Franka Loeve, Cap Volmac (historical implementation)
! Created:    June 11 2026
! Updated:    June 11 2026
! Description:
!   This module computes the momentum stability correction function
!   (psi_m) for unstable and stable atmospheric conditions.
!   References: Holtslag and De Bruin (1987); Hicks (1976).
!------------------------------------------------------------------------------
module m_modmet_fpsim
use modmet_constants, only: pid2, EPS, PI

    implicit none (type, external)
    private
    public :: modmet_fpsim, modmet_fpsim_holtslag
contains
   ! ===========================================================
   ! Function: modmet_fpsim
   ! Description: Computes the momentum stability correction
   !              function using Beljaars and Holtslag (1991).
   ! input: eta - stability parameter z/L [-]
   ! output: fpsim_result - momentum stability correction [-]
   ! ===========================================================
      !! Computes the momentum stability correction function psi_m.
      !!   Reference: Beljaars and Holtslag (1991); Hicks (1976).
      pure function modmet_fpsim(eta) result(fpsim_result)
         real, intent(in) :: eta
         !! stability parameter z/L [-]
      real :: fpsim_result
      real :: x

      if (eta < 0.0) then
         x = sqrt(sqrt(1.0 - 16.0 * eta))
         fpsim_result = log((1.0 + x)**2 * (1.0 + x**2) / 8.0) - 2.0 * atan(x) + pid2
      else
         if (eta > 200.0) then
            fpsim_result = -0.7 * eta - 10.72
         else
            fpsim_result = -0.7 * eta - (0.75 * eta - 10.72) * exp(-0.35 * eta) - 10.72
         end if
      end if
   end function modmet_fpsim

   !! Computes the momentum stability correction function psi_m using the Holtslag 1984 formulation
   pure function modmet_fpsim_holtslag(z, ol) result(fpsim_result)
      real, intent(in) :: z, ol
      real :: fpsim_result
      real :: eta, y

      eta = z / ol

      if (ol > (0.0 + EPS)) then
         fpsim_result = -17.0 * (1.0 - exp(-0.29 * eta))
      else
         ! v Ulden and Holtslag
         y = (1.0 - 15.0 * eta)**0.25
         fpsim_result = 2.0 * log((1.0 + y) / 2.0) + log((1.0 + y * y) / 2.0) - &
            (2.0 * atan(y)) + (PI / 2.0)  ! 2.4 OPS report
      end if

   end function modmet_fpsim_holtslag
end module m_modmet_fpsim