<HTML> <BODY BGCOLOR=#ccccdd LINK=#0000aa VLINK=#0000ff ALINK=#ff0000 ><BASE TARGET="bottom_target"><PRE>
!
! UnitTest_Define
!
! Module defining the UnitTest object
!       
!
! CREATION HISTORY:
!       Written by:     Paul van Delst, 05-Feb-2007
!                       paul.vandelst@noaa.gov
!

<A NAME='UNITTEST_DEFINE'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_DEFINE' TARGET='top_target'><IMG SRC="../../gif/bar_purple.gif" border=0></A>

MODULE UnitTest_Define,78

  ! ------------------
  ! Environment setup
  ! -----------------
  ! Module usage
  USE Type_Kinds           , ONLY: Byte, Short, Long, Single, Double
  USE Compare_Float_Numbers, ONLY: OPERATOR(.EqualTo.)
  ! Disable implicit typing
  IMPLICIT NONE
  
  ! ------------
  ! Visibilities
  ! ------------
  ! Everything private by default
  PRIVATE
  ! Datatypes
  PUBLIC :: UnitTest_type
  ! Procedures
  PUBLIC :: UnitTest_Init
  PUBLIC :: UnitTest_Setup
  PUBLIC :: UnitTest_Report
  PUBLIC :: UnitTest_Summary
  PUBLIC :: UnitTest_n_Passed
  PUBLIC :: UnitTest_n_Failed
  PUBLIC :: UnitTest_Passed
  PUBLIC :: UnitTest_Assert
  PUBLIC :: UnitTest_IsEqual
  PUBLIC :: UnitTest_IsEqualWithin
  PUBLIC :: UnitTest_DefineVersion


  ! ---------------------
  ! Procedure overloading
  ! ---------------------
  ! PUBLIC procedures
<A NAME='UNITTEST_ISEQUAL'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_ISEQUAL' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  INTERFACE UnitTest_IsEqual
    ! INTEGER(Byte) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! INTEGER(Short) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! INTEGER(Long) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! REAL(Single) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! REAL(Double) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! COMPLEX(Single) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! COMPLEX(Double) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! CHARACTER(*) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
  END INTERFACE UnitTest_IsEqual
  
<A NAME='UNITTEST_ISEQUALWITHIN'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_ISEQUALWITHIN' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  INTERFACE UnitTest_IsEqualWithin
    ! REAL(Single) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! REAL(Double) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! COMPLEX(Single) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
    ! COMPLEX(Double) procedures
    MODULE PROCEDURE
    MODULE PROCEDURE
    MODULE PROCEDURE
  END INTERFACE UnitTest_IsEqualWithin
  
  
  ! PRIVATE procedures
<A NAME='GET_MULTIPLIER'><A href='../../html_code/crtm/UnitTest_Define.f90.html#GET_MULTIPLIER' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  INTERFACE Get_Multiplier
    MODULE PROCEDURE
    MODULE PROCEDURE
  END INTERFACE Get_Multiplier
  
  
  ! -----------------
  ! Module parameters
  ! -----------------
  CHARACTER(*), PARAMETER :: MODULE_VERSION_ID = &amp;
  '$Id: UnitTest_Define.f90 29405 2013-06-20 20:19:52Z paul.vandelst@noaa.gov $'
  INTEGER,      PARAMETER :: SL = 512
  INTEGER,      PARAMETER :: CR = 13
  INTEGER,      PARAMETER :: LF = 10
  CHARACTER(2), PARAMETER :: CRLF = ACHAR(CR)//ACHAR(LF)
  CHARACTER(*), PARAMETER :: RFMT = 'es25.18'
  CHARACTER(*), PARAMETER :: ZFMT = '"(",'//RFMT//',",",'//RFMT//',")"'
  LOGICAL,      PARAMETER :: DEFAULT_VERBOSE = .FALSE.

  ! Message levels
  INTEGER, PARAMETER :: N_MESSAGE_LEVELS = 5
  INTEGER, PARAMETER :: INIT_LEVEL    = 1
  INTEGER, PARAMETER :: SETUP_LEVEL   = 2
  INTEGER, PARAMETER :: TEST_LEVEL    = 3
  INTEGER, PARAMETER :: REPORT_LEVEL  = 4
  INTEGER, PARAMETER :: SUMMARY_LEVEL = 5
  CHARACTER(*), PARAMETER :: MESSAGE_LEVEL(N_MESSAGE_LEVELS) = &amp;
    (/ 'INIT   ', 'SETUP  ', 'TEST   ', 'REPORT ', 'SUMMARY' /)

  ! ------------------------
  ! Derived type definitions
  ! ------------------------
  !:tdoc+:
  TYPE :: UnitTest_type
    PRIVATE
    ! User accessible test settings
    LOGICAL       :: Verbose = DEFAULT_VERBOSE
    CHARACTER(SL) :: Title   = ''
    CHARACTER(SL) :: Caller  = ''
    ! Internal test settings
    ! ...Test result messaging
    INTEGER       :: Level     = INIT_LEVEL
    CHARACTER(SL) :: Procedure = ''
    CHARACTER(SL) :: Message   = ''
    ! ...Test result (used for array argument procedures)
    LOGICAL :: Test_Result = .TRUE.
    ! ...Individual test counters
    INTEGER :: n_Tests        = 0
    INTEGER :: n_Passed_Tests = 0
    INTEGER :: n_Failed_Tests = 0
    ! ...All test counters
    INTEGER :: n_AllTests        = 0
    INTEGER :: n_Passed_AllTests = 0
    INTEGER :: n_Failed_AllTests = 0
  END TYPE UnitTest_type
  !:tdoc-:
  
CONTAINS


!################################################################################
!################################################################################
!##                                                                            ##
!##                         ## PUBLIC MODULE ROUTINES ##                       ##
!##                                                                            ##
!################################################################################
!################################################################################

!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Init
!
! PURPOSE:
!       UnitTest initialisation subroutine.
!
!       This subroutine should be called ONCE, BEFORE ANY tests are performed.
!
! CALLING SEQUENCE:
!       CALL UnitTest_Init( UnitTest, Verbose=Verbose )
!
! OBJECTS:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(OUT)
!
! OPTIONAL INPUTS:
!       Verbose:       Logical argument to control length of reporting output.
!                      If == .FALSE., Only failed tests are reported [DEFAULT].
!                         == .TRUE.,  Both failed and passed tests are reported.
!                      If not specified, default is .TRUE.
!                      UNITS:      N/A
!                      TYPE:       LOGICAL
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN), OPTIONAL
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_INIT'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_INIT' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_Init( UnitTest, Verbose ),2
    ! Arguments
    TYPE(UnitTest_type), INTENT(OUT) :: UnitTest
    LOGICAL,   OPTIONAL, INTENT(IN)  :: Verbose
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_Init'
    ! Variables
    LOGICAL :: local_Verbose
    
    ! Check optional arguments
    local_Verbose = DEFAULT_VERBOSE
    IF ( PRESENT(Verbose) ) local_Verbose = Verbose

    ! Perform initialisation
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Verbose = local_Verbose, &amp;
      Level     = INIT_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      n_Tests        = 0, &amp;
      n_Passed_Tests = 0, &amp;
      n_Failed_Tests = 0, &amp;
      n_AllTests        = 0, &amp;
      n_Passed_AllTests = 0, &amp;
      n_Failed_AllTests = 0  )
    CALL Display_Message( UnitTest )
  END SUBROUTINE UnitTest_Init


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Setup
!
! PURPOSE:
!       UnitTest individual test setup subroutine.
!
!       This subroutine should be called BEFORE each set of tests performed.
!
! CALLING SEQUENCE:
!       CALL UnitTest_Setup( UnitTest         , &amp;
!                            Title            , &amp;
!                            Caller  = Caller , &amp;
!                            Verbose = Verbose  )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
! INPUTS:
!       Title:         Character string containing the title of the test
!                      to be performed.
!                      UNITS:      N/A
!                      TYPE:       CHARACTER(*)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
! OPTIONAL INPUTS:
!       Caller:        Character string containing the name of the calling
!                      subprogram. If not specified, default is an empty string.
!                      UNITS:      N/A
!                      TYPE:       CHARACTER(*)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Verbose:       Logical argument to control length of reporting output.
!                      If == .FALSE., Only failed tests are reported [DEFAULT].
!                         == .TRUE.,  Both failed and passed tests are reported.
!                      If not specified, default is .TRUE.
!                      UNITS:      N/A
!                      TYPE:       LOGICAL
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN), OPTIONAL
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_SETUP'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_SETUP' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_Setup( UnitTest, Title, Caller, Verbose ),2
    ! Arguments
    TYPE(UnitTest_type)   , INTENT(IN OUT) :: UnitTest
    CHARACTER(*)          , INTENT(IN)     :: Title
    CHARACTER(*), OPTIONAL, INTENT(IN)     :: Caller
    LOGICAL,      OPTIONAL, INTENT(IN)     :: Verbose
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_Setup'
    ! Variables
    CHARACTER(SL) :: local_Caller
    LOGICAL       :: local_Verbose
    CHARACTER(SL) :: Message

    ! Check arguments
    local_Caller = ''
    IF ( PRESENT(Caller) ) local_Caller = '; CALLER: '//TRIM(ADJUSTL(Caller))
    local_Verbose = DEFAULT_VERBOSE
    IF ( PRESENT(Verbose) ) local_Verbose = Verbose

    ! Create init message
    Message = TRIM(Title)//TRIM(local_Caller)

    ! Perform initialistion
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Title   = ADJUSTL(Title), &amp;
      Caller  = local_Caller  , &amp;
      Verbose = local_Verbose , &amp;
      Level     = SETUP_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message, &amp;
      n_Tests        = 0, &amp;
      n_Passed_Tests = 0, &amp;
      n_Failed_Tests = 0  )
    CALL Display_Message( UnitTest )
                            
  END SUBROUTINE UnitTest_Setup


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Report
!
! PURPOSE:
!       UnitTest individual test report subroutine
!
!       This subroutine should be called AFTER each set of tests performed.
!
! CALLING SEQUENCE:
!       CALL UnitTest_Report( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_REPORT'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_REPORT' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_Report( UnitTest ),3
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_Report'
    ! Variables
    INTEGER :: n_Tests       
    INTEGER :: n_Passed_Tests
    INTEGER :: n_Failed_Tests
    CHARACTER(SL) :: Message
    CHARACTER(SL) :: Attention

    ! Retrieve required properties
    CALL Get_Property( &amp;
      UnitTest, &amp;
      n_Tests        = n_Tests       , &amp;
      n_Passed_Tests = n_Passed_Tests, &amp;
      n_Failed_Tests = n_Failed_Tests  )
      
    ! Test fail attention-grabber
    Attention = ''
    IF ( n_Failed_Tests /= 0 ) Attention = '  &lt;----&lt;&lt;&lt;  **WARNING**'

    ! Output results
    WRITE( Message, &amp;
      '(a,3x,"Passed ",i0," of ",i0," tests", &amp;
       &amp;a,3x,"Failed ",i0," of ",i0," tests",a)') &amp;
      CRLF, &amp;
      n_Passed_Tests, n_Tests, &amp;
      CRLF, &amp;
      n_Failed_Tests, n_Tests, &amp;
      TRIM(Attention)
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = REPORT_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    CALL Display_Message( UnitTest )
  END SUBROUTINE UnitTest_Report


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Summary
!
! PURPOSE:
!       UnitTest test suite report summary subroutine
!
!       This subroutine should be called ONCE, AFTER ALL tests are performed.
!
! CALLING SEQUENCE:
!       CALL UnitTest_Summary( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_SUMMARY'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_SUMMARY' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_Summary( UnitTest ),3
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_Summary'
    ! Variables
    INTEGER :: n_AllTests       
    INTEGER :: n_Passed_AllTests
    INTEGER :: n_Failed_AllTests
    CHARACTER(SL) :: Message
    CHARACTER(SL) :: Attention
    
    ! Retrieve required properties
    CALL Get_Property( &amp;
      UnitTest, &amp;
      n_AllTests        = n_AllTests       , &amp;
      n_Passed_AllTests = n_Passed_AllTests, &amp;
      n_Failed_AllTests = n_Failed_AllTests  )
      
    ! Test fail attention-grabber
    Attention = ''
    IF ( n_Failed_AllTests /= 0 ) Attention = '  &lt;----&lt;&lt;&lt;  **WARNING**'

    ! Output results
    WRITE( Message, &amp;
      '(a,1x,"Passed ",i0," of ",i0," total tests",&amp;
       &amp;a,1x,"Failed ",i0," of ",i0," total tests",a)') &amp;
      CRLF, &amp;
      n_Passed_AllTests, n_AllTests, &amp;
      CRLF, &amp;
      n_Failed_AllTests, n_AllTests, &amp;
      TRIM(Attention)
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = SUMMARY_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    CALL Display_Message( UnitTest )
  END SUBROUTINE UnitTest_Summary


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_n_Passed
!
! PURPOSE:
!       Utility function to return the number of tests passed.
!
! CALLING SEQUENCE:
!       n = UnitTest_n_Passed( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
! FUNCTION RESULT:
!       n:             The number of unit tests that have currently passed.
!                      UNITS:      N/A
!                      TYPE:       INTEGER
!                      DIMENSION:  Scalar
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_N_PASSED'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_N_PASSED' TARGET='top_target'><IMG SRC="../../gif/bar_green.gif" border=0></A>

  PURE FUNCTION UnitTest_n_Passed( UnitTest ) RESULT( n ),1
    TYPE(UnitTest_type), INTENT(IN) :: UnitTest
    INTEGER :: n
    CALL Get_Property( UnitTest, n_Passed_Tests = n )
  END FUNCTION UnitTest_n_Passed


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_n_Failed
!
! PURPOSE:
!       Utility function to return the number of tests failed.
!
! CALLING SEQUENCE:
!       n = UnitTest_n_Failed( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
! FUNCTION RESULT:
!       n:             The number of unit tests that have currently failed.
!                      UNITS:      N/A
!                      TYPE:       INTEGER
!                      DIMENSION:  Scalar
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_N_FAILED'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_N_FAILED' TARGET='top_target'><IMG SRC="../../gif/bar_green.gif" border=0></A>

  PURE FUNCTION UnitTest_n_Failed( UnitTest ) RESULT( n ),1
    TYPE(UnitTest_type), INTENT(IN) :: UnitTest
    INTEGER :: n
    CALL Get_Property( UnitTest, n_Failed_Tests = n )
  END FUNCTION UnitTest_n_Failed


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Passed
!
! PURPOSE:
!       Function to inform if the last test performed passed.
!
! CALLING SEQUENCE:
!       result = UnitTest_Passed( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
! FUNCTION RESULT:
!       result:        Logical to indicate if the last test performed passed.
!                      If == .TRUE.,  the last test passed,
!                         == .FALSE., the last test failed.
!                      UNITS:      N/A
!                      TYPE:       LOGICAL
!                      DIMENSION:  Scalar
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_PASSED'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_PASSED' TARGET='top_target'><IMG SRC="../../gif/bar_green.gif" border=0></A>

  PURE FUNCTION UnitTest_Passed( UnitTest ) RESULT( Passed ),1
    TYPE(UnitTest_type), INTENT(IN) :: UnitTest
    LOGICAL :: Passed
    CALL Get_Property( UnitTest, Test_Result = Passed )
  END FUNCTION UnitTest_Passed
  
  
!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_Assert
!
! PURPOSE:
!       Subroutine to assert its test argument
!
! CALLING SEQUENCE:
!       CALL UnitTest_Assert(UnitTest, Test)
!
! OBJECTS:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
! INPUTS:
!       Test:          The logical expression to assert.
!                      UNITS:      N/A
!                      TYPE:       LOGICAL
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='UNITTEST_ASSERT'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_ASSERT' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_Assert(UnitTest, Test),6
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    LOGICAL,             INTENT(IN)     :: Test
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_Assert'
    ! Variables
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    Message = ''
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    
    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    CALL Test_Info_String( UnitTest, Message )
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
    
  END SUBROUTINE UnitTest_Assert
  

!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_IsEqual
!
! PURPOSE:
!       Subroutine to assert that two arguments are equal.
!
! CALLING SEQUENCE:
!       CALL UnitTest_IsEqual( UnitTest, Expected, Actual )
!
! OBJECTS:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
! INPUTS:
!       Expected:      The expected value of the variable being tested.
!                      UNITS:      N/A
!                      TYPE:       INTEGER(Byte)  , or
!                                  INTEGER(Short) , or
!                                  INTEGER(Long)  , or
!                                  REAL(Single)   , or
!                                  REAL(Double)   , or
!                                  COMPLEX(Single), or
!                                  COMPLEX(Double), or
!                                  CHARACTER(*)
!                      DIMENSION:  Scalar, or
!                                  Rank-1, or
!                                  Rank-2
!                      ATTRIBUTES: INTENT(IN)
!
!       Actual:        The actual value of the variable being tested.
!                      UNITS:      N/A
!                      TYPE:       Same as Expected input
!                      DIMENSION:  Same as Expected input
!                      ATTRIBUTES: INTENT(IN)
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='INTBYTE_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTBYTE_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intbyte_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Byte),       INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Byte)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected == Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message,'("Expected ",i0," and got ",i0)') Expected, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE intbyte_isequal_scalar

  
<A NAME='INTBYTE_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTBYTE_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intbyte_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Byte),       INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Byte)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL intbyte_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE intbyte_isequal_rank1

  
<A NAME='INTBYTE_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTBYTE_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intbyte_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Byte),       INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Byte)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL intbyte_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE intbyte_isequal_rank2


<A NAME='INTSHORT_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTSHORT_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intshort_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Short),       INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Short)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected == Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message,'("Expected ",i0," and got ",i0)') Expected, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE intshort_isequal_scalar

  
<A NAME='INTSHORT_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTSHORT_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intshort_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Short),      INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Short)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL intshort_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE intshort_isequal_rank1

  
<A NAME='INTSHORT_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTSHORT_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intshort_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Short),      INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Short)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL intshort_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE intshort_isequal_rank2


<A NAME='INTLONG_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTLONG_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intlong_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Long),       INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Long)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected == Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message,'("Expected ",i0," and got ",i0)') Expected, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE intlong_isequal_scalar

  
<A NAME='INTLONG_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTLONG_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intlong_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Long),       INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Long)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL intlong_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE intlong_isequal_rank1

  
<A NAME='INTLONG_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#INTLONG_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE intlong_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER(Long),       INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[INTEGER(Long)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL intlong_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE intlong_isequal_rank2


<A NAME='REALSP_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Single)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected .EqualTo. Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected: ",'//RFMT//',a,&amp;
         &amp;7x,"And got:  ",'//RFMT//')') &amp;
      CRLF, Expected, CRLF, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE realsp_isequal_scalar

  
<A NAME='REALSP_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Single)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL realsp_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE realsp_isequal_rank1

  
<A NAME='REALSP_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Single)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL realsp_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE realsp_isequal_rank2


<A NAME='REALDP_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Double)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected .EqualTo. Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected: ",'//RFMT//',a,&amp;
         &amp;7x,"And got:  ",'//RFMT//')') &amp;
      CRLF, Expected, CRLF, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE realdp_isequal_scalar

  
<A NAME='REALDP_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Double)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL realdp_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE realdp_isequal_rank1

  
<A NAME='REALDP_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[REAL(Double)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL realdp_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE realdp_isequal_rank2


<A NAME='COMPLEXSP_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Single)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected .EqualTo. Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected: ",'//ZFMT//',a,&amp;
         &amp;7x,"And got:  ",'//ZFMT//')') &amp;
      CRLF, Expected, CRLF, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE complexsp_isequal_scalar

  
<A NAME='COMPLEXSP_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Single)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL complexsp_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE complexsp_isequal_rank1

  
<A NAME='COMPLEXSP_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Single)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL complexsp_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE complexsp_isequal_rank2


<A NAME='COMPLEXDP_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Double)]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected .EqualTo. Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected: ",'//ZFMT//',a,&amp;
         &amp;7x,"And got:  ",'//ZFMT//')') &amp;
      CRLF, Expected, CRLF, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE complexdp_isequal_scalar

  
<A NAME='COMPLEXDP_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Double)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL complexdp_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE complexdp_isequal_rank1

  
<A NAME='COMPLEXDP_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[COMPLEX(Double)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL complexdp_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE complexdp_isequal_rank2
  

<A NAME='CHAR_ISEQUAL_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#CHAR_ISEQUAL_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE char_isequal_scalar( UnitTest, Expected, Actual ) 3,5
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    CHARACTER(*),        INTENT(IN)     :: Expected, Actual
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[CHARACTER]'
    ! Variables
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Assign the test
    Test = (Expected == Actual)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message,'("Expected &gt;",a,"&lt; and got &gt;",a,"&lt;")') Expected, Actual
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE char_isequal_scalar

  
<A NAME='CHAR_ISEQUAL_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#CHAR_ISEQUAL_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE char_isequal_rank1( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    CHARACTER(*),        INTENT(IN)     :: Expected(:), Actual(:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[CHARACTER]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0)') &amp;
        isize, SIZE(Actual)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL char_isequal_scalar( UnitTest, Expected(i), Actual(i) )
    END DO
  END SUBROUTINE char_isequal_rank1

  
<A NAME='CHAR_ISEQUAL_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#CHAR_ISEQUAL_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE char_isequal_rank2( UnitTest, Expected, Actual ) 1,4
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    CHARACTER(*),        INTENT(IN)     :: Expected(:,:), Actual(:,:)
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqual[CHARACTER]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL char_isequal_scalar( UnitTest, Expected(i,j), Actual(i,j) )
      END DO
    END DO
  END SUBROUTINE char_isequal_rank2


!------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_IsEqualWithin
!
! PURPOSE:
!       Subroutine to assert that two floating point arguments are equal to
!       within the specified tolerance.
!
! CALLING SEQUENCE:
!       CALL UnitTest_IsEqualWithin( UnitTest , &amp;
!                                    Expected , &amp;
!                                    Actual   , &amp;
!                                    Tolerance, &amp;
!                                    Epsilon_Scale = Epsilon_Scale )
!
! OBJECTS:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
! INPUTS:
!       Expected:      The expected value of the variable being tested.
!                      UNITS:      N/A
!                      TYPE:       REAL(Single)   , or
!                                  REAL(Double)   , or
!                                  COMPLEX(Single), or
!                                  COMPLEX(Double)
!                      DIMENSION:  Scalar, or
!                                  Rank-1, or
!                                  Rank-2
!                      ATTRIBUTES: INTENT(IN)
!
!       Actual:        The actual value of the variable being tested.
!                      UNITS:      N/A
!                      TYPE:       Same as Expected input
!                      DIMENSION:  Same as Expected input
!                      ATTRIBUTES: INTENT(IN)
!
!       Tolerance:     The tolerance to within which the Expected and Actual
!                      values must agree. If negative, the value of
!                        EPSILON(Expected)
!                      is used.
!                      This argument is ignored if the EPSILON_SCALE optional
!                      argument is specified
!                      UNITS:      N/A
!                      TYPE:       Same as Expected input
!                      DIMENSION:  Same as Expected input
!                      ATTRIBUTES: INTENT(IN)
!
! OPTIONAL INPUTS:
!       Epsilon_Scale: Set this logical flag to compute and use the tolerance
!                      value:
!                        EPSILON(Expected) * Scale_Factor
!                      where the scaling factor is the exponent value of the
!                      input argument Expected.
!                      UNITS:      N/A
!                      TYPE:       LOGICAL.
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
!:sdoc-:
!------------------------------------------------------------------------------

<A NAME='REALSP_ISEQUALWITHIN_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUALWITHIN_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequalwithin_scalar( &amp; 3,5
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected, Actual, Tolerance
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Single)]'
    ! Variables
    REAL(Single) :: tol
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Default tolerance
    tol = Tolerance
    ! ...Check optional arguments
    IF ( PRESENT(Epsilon_Scale) ) THEN
      IF ( Epsilon_Scale ) tol = EPSILON(Expected) * Get_Multiplier( Expected )
    END IF
    ! ...Assign the test
    Test = (ABS(Expected-Actual) &lt; tol)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected:     ",'//RFMT//',a,&amp;
         &amp;7x,"To within:    ",'//RFMT//',a,&amp;
         &amp;7x,"And got:      ",'//RFMT//',a,&amp;
         &amp;7x,"|Difference|: ",'//RFMT//')') &amp;
      CRLF, Expected, CRLF, tol, CRLF, Actual, CRLF, ABS(Expected-Actual)
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE realsp_isequalwithin_scalar

  
<A NAME='REALSP_ISEQUALWITHIN_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUALWITHIN_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequalwithin_rank1(  &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected(:), Actual(:), Tolerance(:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Single)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual)    /= isize .OR. &amp;
         SIZE(Tolerance) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0,"; Tolerance:",i0)') &amp;
        isize, SIZE(Actual), SIZE(Tolerance)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL realsp_isequalwithin_scalar( &amp;
        UnitTest    , &amp;
        Expected(i) , &amp;
        Actual(i)   , &amp;
        Tolerance(i), &amp;
        Epsilon_Scale = Epsilon_Scale )
    END DO
  END SUBROUTINE realsp_isequalwithin_rank1

  
<A NAME='REALSP_ISEQUALWITHIN_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_ISEQUALWITHIN_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realsp_isequalwithin_rank2( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Single),        INTENT(IN)     :: Expected(:,:), Actual(:,:), Tolerance(:,:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Single)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize .OR. &amp;
         SIZE(Tolerance,DIM=1) /= isize .OR. &amp;
         SIZE(Tolerance,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- ",&amp;
        &amp;"Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,"); Tolerance:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2), &amp;
        SIZE(Tolerance,DIM=1), SIZE(Tolerance,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL realsp_isequalwithin_scalar( &amp;
          UnitTest      , &amp;
          Expected(i,j) , &amp;
          Actual(i,j)   , &amp;
          Tolerance(i,j), &amp;
          Epsilon_Scale = Epsilon_Scale )
      END DO
    END DO
  END SUBROUTINE realsp_isequalwithin_rank2


<A NAME='REALDP_ISEQUALWITHIN_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUALWITHIN_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequalwithin_scalar( &amp; 3,5
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected, Actual, Tolerance
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Double)]'
    ! Variables
    REAL(Double) :: tol
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Default tolerance
    tol = Tolerance
    ! ...Check optional arguments
    IF ( PRESENT(Epsilon_Scale) ) THEN
      IF ( Epsilon_Scale ) tol = EPSILON(Expected) * Get_Multiplier( Expected )
    END IF
    ! ...Assign the test
    Test = (ABS(Expected-Actual) &lt; tol)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected:     ",'//RFMT//',a,&amp;
         &amp;7x,"To within:    ",'//RFMT//',a,&amp;
         &amp;7x,"And got:      ",'//RFMT//',a,&amp;
         &amp;7x,"|Difference|: ",'//RFMT//')') &amp;
      CRLF, Expected, CRLF, tol, CRLF, Actual, CRLF, ABS(Expected-Actual)
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE realdp_isequalwithin_scalar

  
<A NAME='REALDP_ISEQUALWITHIN_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUALWITHIN_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequalwithin_rank1(  &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected(:), Actual(:), Tolerance(:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Double)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual)    /= isize .OR. &amp;
         SIZE(Tolerance) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0,"; Tolerance:",i0)') &amp;
        isize, SIZE(Actual), SIZE(Tolerance)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL realdp_isequalwithin_scalar( &amp;
        UnitTest    , &amp;
        Expected(i) , &amp;
        Actual(i)   , &amp;
        Tolerance(i), &amp;
        Epsilon_Scale = Epsilon_Scale )
    END DO
  END SUBROUTINE realdp_isequalwithin_rank1

  
<A NAME='REALDP_ISEQUALWITHIN_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_ISEQUALWITHIN_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE realdp_isequalwithin_rank2( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    REAL(Double),        INTENT(IN)     :: Expected(:,:), Actual(:,:), Tolerance(:,:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[REAL(Double)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize .OR. &amp;
         SIZE(Tolerance,DIM=1) /= isize .OR. &amp;
         SIZE(Tolerance,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- ",&amp;
        &amp;"Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,"); Tolerance:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2), &amp;
        SIZE(Tolerance,DIM=1), SIZE(Tolerance,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL realdp_isequalwithin_scalar( &amp;
          UnitTest      , &amp;
          Expected(i,j) , &amp;
          Actual(i,j)   , &amp;
          Tolerance(i,j), &amp;
          Epsilon_Scale = Epsilon_Scale )
      END DO
    END DO
  END SUBROUTINE realdp_isequalwithin_rank2


<A NAME='COMPLEXSP_ISEQUALWITHIN_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUALWITHIN_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequalwithin_scalar( &amp; 3,5
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected, Actual, Tolerance
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Single)]'
    ! Variables
    REAL(Single) :: tolr, toli
    REAL(Single) :: zr, zi
    REAL(Single) :: dzr, dzi
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Split expected into real and imag
    zr = REAL(Expected,Single)
    zi = AIMAG(Expected)
    ! ...Default tolerance
    tolr = REAL(Tolerance,Single)
    toli = AIMAG(Tolerance) 
    ! ...Check optional arguments
    IF ( PRESENT(Epsilon_Scale) ) THEN
      IF ( Epsilon_Scale ) THEN
        tolr = EPSILON(zr) * Get_Multiplier(zr)
        toli = EPSILON(zi) * Get_Multiplier(zi)
      END IF
    END IF
    ! ...Assign the test
    dzr = ABS(zr - REAL(Actual,Single))
    dzi = ABS(zi - AIMAG(Actual))
    Test = (dzr &lt; tolr) .AND. (dzi &lt; toli)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected:     ",'//ZFMT//',a,&amp;
         &amp;7x,"To within:    ",'//ZFMT//',a,&amp;
         &amp;7x,"And got:      ",'//ZFMT//',a,&amp;
         &amp;7x,"|Difference|: ",'//ZFMT//')') &amp;
      CRLF, Expected, CRLF, CMPLX(tolr,toli,Single), CRLF, Actual, CRLF, dzr, dzi
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE complexsp_isequalwithin_scalar

  
<A NAME='COMPLEXSP_ISEQUALWITHIN_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUALWITHIN_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequalwithin_rank1( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected(:), Actual(:), Tolerance(:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Single)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual)    /= isize .OR. &amp;
         SIZE(Tolerance) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0,"; Tolerance:",i0)') &amp;
        isize, SIZE(Actual), SIZE(Tolerance)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL complexsp_isequalwithin_scalar( &amp;
        UnitTest    , &amp;
        Expected(i) , &amp;
        Actual(i)   , &amp;
        Tolerance(i), &amp;
        Epsilon_Scale = Epsilon_Scale )
    END DO
  END SUBROUTINE complexsp_isequalwithin_rank1

  
<A NAME='COMPLEXSP_ISEQUALWITHIN_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXSP_ISEQUALWITHIN_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexsp_isequalwithin_rank2( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Single),     INTENT(IN)     :: Expected(:,:), Actual(:,:), Tolerance(:,:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Single)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize .OR. &amp;
         SIZE(Tolerance,DIM=1) /= isize .OR. &amp;
         SIZE(Tolerance,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- ",&amp;
        &amp;"Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,"); Tolerance:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2), &amp;
        SIZE(Tolerance,DIM=1), SIZE(Tolerance,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL complexsp_isequalwithin_scalar( &amp;
          UnitTest      , &amp;
          Expected(i,j) , &amp;
          Actual(i,j)   , &amp;
          Tolerance(i,j), &amp;
          Epsilon_Scale = Epsilon_Scale )
      END DO
    END DO
  END SUBROUTINE complexsp_isequalwithin_rank2


<A NAME='COMPLEXDP_ISEQUALWITHIN_SCALAR'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUALWITHIN_SCALAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequalwithin_scalar( &amp; 3,5
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected, Actual, Tolerance
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Double)]'
    ! Variables
    REAL(Double) :: tolr, toli
    REAL(Double) :: zr, zi
    REAL(Double) :: dzr, dzi
    LOGICAL :: Test
    LOGICAL :: Verbose
    CHARACTER(SL) :: Message
    
    ! Setup
    ! ...Split expected into real and imag
    zr = REAL(Expected,Double)
    zi = AIMAG(Expected)
    ! ...Default tolerance
    tolr = REAL(Tolerance,Double)
    toli = AIMAG(Tolerance) 
    ! ...Check optional arguments
    IF ( PRESENT(Epsilon_Scale) ) THEN
      IF ( Epsilon_Scale ) THEN
        tolr = EPSILON(zr) * Get_Multiplier(zr)
        toli = EPSILON(zi) * Get_Multiplier(zi)
      END IF
    END IF
    ! ...Assign the test
    dzr = ABS(zr - REAL(Actual,Double))
    dzi = ABS(zi - AIMAG(Actual))
    Test = (dzr &lt; tolr) .AND. (dzi &lt; toli)
    ! ...Locally modify properties for this test
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Verbose = Verbose )
    Verbose = Verbose .OR. (.NOT. Test)  ! Always output test failure
    

    ! Assert the test
    IF ( Test ) THEN
      CALL Test_Passed( UnitTest )
    ELSE
      CALL Test_Failed( UnitTest )
    END IF
    
    ! Output message
    WRITE( Message, &amp;
      '(a,7x,"Expected:     ",'//ZFMT//',a,&amp;
         &amp;7x,"To within:    ",'//ZFMT//',a,&amp;
         &amp;7x,"And got:      ",'//ZFMT//',a,&amp;
         &amp;7x,"|Difference|: ",'//ZFMT//')') &amp;
      CRLF, Expected, CRLF, CMPLX(tolr,toli,Double), CRLF, Actual, CRLF, dzr, dzi
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Level = TEST_LEVEL, &amp;
      Procedure = PROCEDURE_NAME, &amp;
      Message = Message )
    IF ( Verbose ) CALL Display_Message( UnitTest )
  END SUBROUTINE complexdp_isequalwithin_scalar

  
<A NAME='COMPLEXDP_ISEQUALWITHIN_RANK1'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUALWITHIN_RANK1' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequalwithin_rank1( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected(:), Actual(:), Tolerance(:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Double)]'
    ! Variables
    INTEGER :: i, isize
    CHARACTER(SL) :: Message

    ! Check array sizes
    isize = SIZE(Expected)
    IF ( SIZE(Actual)    /= isize .OR. &amp;
         SIZE(Tolerance) /= isize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- Expected:",i0,"; Actual:",i0,"; Tolerance:",i0)') &amp;
        isize, SIZE(Actual), SIZE(Tolerance)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO i = 1, isize
      CALL complexdp_isequalwithin_scalar( &amp;
        UnitTest    , &amp;
        Expected(i) , &amp;
        Actual(i)   , &amp;
        Tolerance(i), &amp;
        Epsilon_Scale = Epsilon_Scale )
    END DO
  END SUBROUTINE complexdp_isequalwithin_rank1

  
<A NAME='COMPLEXDP_ISEQUALWITHIN_RANK2'><A href='../../html_code/crtm/UnitTest_Define.f90.html#COMPLEXDP_ISEQUALWITHIN_RANK2' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE complexdp_isequalwithin_rank2( &amp; 1,4
    UnitTest     , &amp;
    Expected     , &amp;
    Actual       , &amp;
    Tolerance    , &amp;
    Epsilon_Scale  )
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    COMPLEX(Double),     INTENT(IN)     :: Expected(:,:), Actual(:,:), Tolerance(:,:)
    LOGICAL,   OPTIONAL, INTENT(IN)     :: Epsilon_Scale
    ! Parameters
    CHARACTER(*), PARAMETER :: PROCEDURE_NAME = 'UnitTest_IsEqualWithin[COMPLEX(Double)]'
    ! Variables
    INTEGER :: i, j, isize, jsize
    CHARACTER(SL) :: Message
    
    ! Check array sizes
    isize = SIZE(Expected,DIM=1); jsize = SIZE(Expected,DIM=2)
    IF ( SIZE(Actual,DIM=1) /= isize .OR. &amp;
         SIZE(Actual,DIM=2) /= jsize .OR. &amp;
         SIZE(Tolerance,DIM=1) /= isize .OR. &amp;
         SIZE(Tolerance,DIM=2) /= jsize ) THEN
      CALL Test_Failed( UnitTest )
      WRITE( Message, &amp;
        '("Array sizes are diffferent -- ",&amp;
        &amp;"Expected:(",i0,",",i0,"); Actual:(",i0,",",i0,"); Tolerance:(",i0,",",i0,")")') &amp;
        isize, jsize, &amp;
        SIZE(Actual,DIM=1), SIZE(Actual,DIM=2), &amp;
        SIZE(Tolerance,DIM=1), SIZE(Tolerance,DIM=2)
      CALL Set_Property( &amp;
        UnitTest, &amp;
        Level = TEST_LEVEL, &amp;
        Procedure = PROCEDURE_NAME, &amp;
        Message = Message )
      CALL Display_Message( UnitTest )
      RETURN
    ENDIF
    
    ! Loop over elements
    DO j = 1, jsize
      DO i = 1, isize
        CALL complexdp_isequalwithin_scalar( &amp;
          UnitTest      , &amp;
          Expected(i,j) , &amp;
          Actual(i,j)   , &amp;
          Tolerance(i,j), &amp;
          Epsilon_Scale = Epsilon_Scale )
      END DO
    END DO
  END SUBROUTINE complexdp_isequalwithin_rank2
  

!--------------------------------------------------------------------------------
!:sdoc+:
!
! NAME:
!       UnitTest_DefineVersion
!
! PURPOSE:
!       Subroutine to return the module version information.
!
! CALLING SEQUENCE:
!       CALL UnitTest_DefineVersion( Id )
!
! OUTPUTS:
!       Id:    Character string containing the version Id information
!              for the module.
!              UNITS:      N/A
!              TYPE:       CHARACTER(*)
!              DIMENSION:  Scalar
!              ATTRIBUTES: INTENT(OUT)
!
!:sdoc-:
!--------------------------------------------------------------------------------

<A NAME='UNITTEST_DEFINEVERSION'><A href='../../html_code/crtm/UnitTest_Define.f90.html#UNITTEST_DEFINEVERSION' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE UnitTest_DefineVersion( Id )
    CHARACTER(*), INTENT(OUT) :: Id
    Id = MODULE_VERSION_ID
  END SUBROUTINE UnitTest_DefineVersion
  

!################################################################################
!################################################################################
!##                                                                            ##
!##                        ## PRIVATE MODULE ROUTINES ##                       ##
!##                                                                            ##
!################################################################################
!################################################################################

!===================
! METHOD PROCEDURES
!===================

!------------------------------------------------------------------------------
!
! NAME:
!       Set_Property
!
! PURPOSE:
!       Private subroutine to set the properties of a UnitTest object.
!
!       All WRITE access to the UnitTest object properties should be
!       done using this subroutine.
!
! CALLING SEQUENCE:
!       CALL Set_Property( &amp;
!         UnitTest, &amp;
!         Verbose           = Verbose          , &amp;
!         Title             = Title            , &amp;
!         Caller            = Caller           , &amp;
!         Level             = Level            , &amp;
!         Procedure         = Procedure        , &amp;
!         Message           = Message          , &amp;
!         Test_Result       = Test_Result      , &amp;
!         n_Tests           = n_Tests          , &amp;
!         n_Passed_Tests    = n_Passed_Tests   , &amp;
!         n_Failed_Tests    = n_Failed_Tests   , &amp;
!         n_AllTests        = n_AllTests       , &amp;
!         n_Passed_AllTests = n_Passed_AllTests, &amp;
!         n_Failed_AllTests = n_Failed_AllTests  )
!
! OBJECT:
!       UnitTest:           UnitTest object.
!                           UNITS:      N/A
!                           TYPE:       TYPE(UnitTest_type)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN OUT)
!
! OPTIONAL INPUTS:
!       Verbose:            Logical to control length of reporting output.
!                           If == .FALSE., Only failed tests are reported.
!                              == .TRUE.,  Both failed and passed tests are reported.
!                           UNITS:      N/A
!                           TYPE:       LOGICAL
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Title:              Character string containing the title of the
!                           test to be performed.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Caller:             Character string containing the name of the
!                           calling subprogram.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Level:              Integer flag specifying the output message level.
!                           UNITS:      N/A
!                           TYPE:       INTEGER     
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Procedure:          The name of the UnitTest procedure.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Message:            Character string containing an informational
!                           message about the unit test performed.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Test_Result:        Logical to contain the result of unit tests
!                           performed
!                           If == .TRUE.,  Test passed.
!                              == .FALSE., Test failed.
!                           UNITS:      N/A
!                           TYPE:       LOGICAL
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_Tests:            The number of tests performed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_Passed_Tests:     The number of tests passed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_Failed_Tests:     The number of tests failed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_AllTests:         The total number of tests performed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_Passed_AllTests:  The total number of tests passed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       n_Failed_AllTests:  The total number of tests failed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!------------------------------------------------------------------------------

<A NAME='SET_PROPERTY'><A href='../../html_code/crtm/UnitTest_Define.f90.html#SET_PROPERTY' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  PURE SUBROUTINE Set_Property( &amp; 44
    UnitTest         , &amp; ! Object
    Verbose          , &amp; ! Optional input
    Title            , &amp; ! Optional input
    Caller           , &amp; ! Optional input
    Level            , &amp; ! Optional input
    Procedure        , &amp; ! Optional input
    Message          , &amp; ! Optional input
    Test_Result      , &amp; ! Optional input
    n_Tests          , &amp; ! Optional input
    n_Passed_Tests   , &amp; ! Optional input
    n_Failed_Tests   , &amp; ! Optional input
    n_AllTests       , &amp; ! Optional input
    n_Passed_AllTests, &amp; ! Optional input
    n_Failed_AllTests  ) ! Optional input
    ! Arguments
    TYPE(UnitTest_type)   , INTENT(IN OUT) :: UnitTest
    LOGICAL     , OPTIONAL, INTENT(IN)     :: Verbose
    CHARACTER(*), OPTIONAL, INTENT(IN)     :: Title  
    CHARACTER(*), OPTIONAL, INTENT(IN)     :: Caller 
    INTEGER     , OPTIONAL, INTENT(IN)     :: Level
    CHARACTER(*), OPTIONAL, INTENT(IN)     :: Procedure
    CHARACTER(*), OPTIONAL, INTENT(IN)     :: Message   
    LOGICAL     , OPTIONAL, INTENT(IN)     :: Test_Result
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_Tests       
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_Passed_Tests
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_Failed_Tests
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_AllTests       
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_Passed_AllTests
    INTEGER     , OPTIONAL, INTENT(IN)     :: n_Failed_AllTests
    ! Set the object properties
    IF ( PRESENT(Verbose          ) ) UnitTest%Verbose           = Verbose
    IF ( PRESENT(Title            ) ) UnitTest%Title             = Title  
    IF ( PRESENT(Caller           ) ) UnitTest%Caller            = Caller 
    IF ( PRESENT(Level            ) ) UnitTest%Level             = Level 
    IF ( PRESENT(Procedure        ) ) UnitTest%Procedure         = Procedure
    IF ( PRESENT(Message          ) ) UnitTest%Message           = Message   
    IF ( PRESENT(Test_Result      ) ) UnitTest%Test_Result       = Test_Result
    IF ( PRESENT(n_Tests          ) ) UnitTest%n_Tests           = n_Tests       
    IF ( PRESENT(n_Passed_Tests   ) ) UnitTest%n_Passed_Tests    = n_Passed_Tests
    IF ( PRESENT(n_Failed_Tests   ) ) UnitTest%n_Failed_Tests    = n_Failed_Tests
    IF ( PRESENT(n_AllTests       ) ) UnitTest%n_AllTests        = n_AllTests       
    IF ( PRESENT(n_Passed_AllTests) ) UnitTest%n_Passed_AllTests = n_Passed_AllTests
    IF ( PRESENT(n_Failed_AllTests) ) UnitTest%n_Failed_AllTests = n_Failed_AllTests
  END SUBROUTINE Set_Property


!------------------------------------------------------------------------------
!
! NAME:
!       Get_Property
!
! PURPOSE:
!       Private subroutine to get the properties of a UnitTest object.
!
!       All READ access to the UnitTest object properties should be
!       done using this subroutine.
!
! CALLING SEQUENCE:
!       CALL Get_Property( &amp;
!         UnitTest, &amp;
!         Verbose           = Verbose          , &amp;
!         Title             = Title            , &amp;
!         Caller            = Caller           , &amp;
!         Level             = Level            , &amp;
!         Procedure         = Procedure        , &amp;
!         Message           = Message          , &amp;
!         Test_Result       = Test_Result      , &amp;
!         n_Tests           = n_Tests          , &amp;
!         n_Passed_Tests    = n_Passed_Tests   , &amp;
!         n_Failed_Tests    = n_Failed_Tests   , &amp;
!         n_AllTests        = n_AllTests       , &amp;
!         n_Passed_AllTests = n_Passed_AllTests, &amp;
!         n_Failed_AllTests = n_Failed_AllTests  )
!
! OBJECT:
!       UnitTest:           UnitTest object.
!                           UNITS:      N/A
!                           TYPE:       TYPE(UnitTest_type)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN)
!
! OPTIONAL OUTPUTS:
!       Verbose:            Logical to control length of reporting output.
!                           If == .FALSE., Only failed tests are reported.
!                              == .TRUE.,  Both failed and passed tests are reported.
!                           UNITS:      N/A
!                           TYPE:       LOGICAL
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       Title:              Character string containing the title of the
!                           test to be performed.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       Caller:             Character string containing the name of the
!                           calling subprogram.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       Level:              Integer flag specifying the output message level.
!                           UNITS:      N/A
!                           TYPE:       INTEGER     
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       Procedure:          The name of the last UnitTest Procedure called.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(IN), OPTIONAL
!
!       Message:            Character string containing an informational
!                           message about the last unit test performed.
!                           UNITS:      N/A
!                           TYPE:       CHARACTER(*)
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       Test_Result:        Logical containing the result of the last
!                           unit test performed
!                           If == .TRUE.,  Test passed.
!                              == .FALSE., Test failed.
!                           UNITS:      N/A
!                           TYPE:       LOGICAL
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_Tests:            The number of tests performed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_Passed_Tests:     The number of tests passed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_Failed_Tests:     The number of tests failed for the current
!                           unit test type, i.e. since the last call to
!                           UnitTest_Setup().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_AllTests:         The total number of tests performed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_Passed_AllTests:  The total number of tests passed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!       n_Failed_AllTests:  The total number of tests failed, i.e. since
!                           the last call to UnitTest_Init().
!                           UNITS:      N/A
!                           TYPE:       INTEGER
!                           DIMENSION:  Scalar
!                           ATTRIBUTES: INTENT(OUT), OPTIONAL
!
!------------------------------------------------------------------------------

<A NAME='GET_PROPERTY'><A href='../../html_code/crtm/UnitTest_Define.f90.html#GET_PROPERTY' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  PURE SUBROUTINE Get_Property( &amp; 23
    UnitTest         , &amp; ! Object
    Verbose          , &amp; ! Optional output
    Title            , &amp; ! Optional output
    Caller           , &amp; ! Optional output
    Level            , &amp; ! Optional output
    Procedure        , &amp; ! Optional output
    Message          , &amp; ! Optional output
    Test_Result      , &amp; ! Optional output
    n_Tests          , &amp; ! Optional output
    n_Passed_Tests   , &amp; ! Optional output
    n_Failed_Tests   , &amp; ! Optional output
    n_AllTests       , &amp; ! Optional output
    n_Passed_AllTests, &amp; ! Optional output
    n_Failed_AllTests  ) ! Optional output
    ! Arguments
    TYPE(UnitTest_type)   , INTENT(IN)  :: UnitTest
    LOGICAL     , OPTIONAL, INTENT(OUT) :: Verbose
    CHARACTER(*), OPTIONAL, INTENT(OUT) :: Title  
    CHARACTER(*), OPTIONAL, INTENT(OUT) :: Caller 
    INTEGER     , OPTIONAL, INTENT(OUT) :: Level  
    CHARACTER(*), OPTIONAL, INTENT(OUT) :: Procedure   
    CHARACTER(*), OPTIONAL, INTENT(OUT) :: Message   
    LOGICAL     , OPTIONAL, INTENT(OUT) :: Test_Result
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_Tests       
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_Passed_Tests
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_Failed_Tests
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_AllTests       
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_Passed_AllTests
    INTEGER     , OPTIONAL, INTENT(OUT) :: n_Failed_AllTests
    ! Get the object properties
    IF ( PRESENT(Verbose          ) ) Verbose           = UnitTest%Verbose          
    IF ( PRESENT(Title            ) ) Title             = UnitTest%Title            
    IF ( PRESENT(Caller           ) ) Caller            = UnitTest%Caller           
    IF ( PRESENT(Level            ) ) Level             = UnitTest%Level            
    IF ( PRESENT(Procedure        ) ) Procedure         = UnitTest%Procedure        
    IF ( PRESENT(Message          ) ) Message           = UnitTest%Message          
    IF ( PRESENT(Test_Result      ) ) Test_Result       = UnitTest%Test_Result      
    IF ( PRESENT(n_Tests          ) ) n_Tests           = UnitTest%n_Tests          
    IF ( PRESENT(n_Passed_Tests   ) ) n_Passed_Tests    = UnitTest%n_Passed_Tests   
    IF ( PRESENT(n_Failed_Tests   ) ) n_Failed_Tests    = UnitTest%n_Failed_Tests   
    IF ( PRESENT(n_AllTests       ) ) n_AllTests        = UnitTest%n_AllTests       
    IF ( PRESENT(n_Passed_AllTests) ) n_Passed_AllTests = UnitTest%n_Passed_AllTests
    IF ( PRESENT(n_Failed_AllTests) ) n_Failed_AllTests = UnitTest%n_Failed_AllTests
  END SUBROUTINE Get_Property


!------------------------------------------------------------------------------
!
! NAME:
!       Test_Passed
!
! PURPOSE:
!       Subroutine to increment passed test counters.
!
! CALLING SEQUENCE:
!       CALL Test_Passed( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
!------------------------------------------------------------------------------

<A NAME='TEST_PASSED'><A href='../../html_code/crtm/UnitTest_Define.f90.html#TEST_PASSED' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE Test_Passed( UnitTest ) 13,3
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    ! Variables
    INTEGER :: n_Passed_Tests, n_Passed_AllTests

    ! Increment total test counters
    CALL Test_Increment( UnitTest )

    ! Increment the passed test counters
    ! ...Get 'em
    CALL Get_Property( &amp;
      UnitTest, &amp;
      n_Passed_Tests = n_Passed_Tests, &amp;
      n_Passed_AllTests = n_Passed_AllTests )
    ! ...Increment
    n_Passed_Tests    = n_Passed_Tests    + 1
    n_Passed_AllTests = n_Passed_AllTests + 1
    ! ...Save 'em and set successful test result 
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Test_Result = .TRUE., &amp;
      n_Passed_Tests = n_Passed_Tests, &amp;
      n_Passed_AllTests = n_Passed_AllTests )
  END SUBROUTINE Test_Passed


!------------------------------------------------------------------------------
!
! NAME:
!       Test_Failed
!
! PURPOSE:
!       Subroutine to increment failed test counters.
!
! CALLING SEQUENCE:
!       CALL Test_Failed( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
!------------------------------------------------------------------------------

<A NAME='TEST_FAILED'><A href='../../html_code/crtm/UnitTest_Define.f90.html#TEST_FAILED' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE Test_Failed( UnitTest ) 37,3
    ! Arguments
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    ! Variables
    INTEGER :: n_Failed_Tests, n_Failed_AllTests

    ! Increment total test counters
    CALL Test_Increment( UnitTest )

    ! Increment the failed test counters
    ! ...Get 'em
    CALL Get_Property( &amp;
      UnitTest, &amp;
      n_Failed_Tests = n_Failed_Tests, &amp;
      n_Failed_AllTests = n_Failed_AllTests )
    ! ...Increment
    n_Failed_Tests    = n_Failed_Tests    + 1
    n_Failed_AllTests = n_Failed_AllTests + 1
    ! ...Save 'em and set unsuccessful test result 
    CALL Set_Property( &amp;
      UnitTest, &amp;
      Test_Result = .FALSE., &amp;
      n_Failed_Tests = n_Failed_Tests, &amp;
      n_Failed_AllTests = n_Failed_AllTests )
  END SUBROUTINE Test_Failed


!------------------------------------------------------------------------------
!
! NAME:
!       Test_Increment
!
! PURPOSE:
!       Subroutine to increment the test total counters.
!
! CALLING SEQUENCE:
!       CALL Test_Increment( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
!------------------------------------------------------------------------------

<A NAME='TEST_INCREMENT'><A href='../../html_code/crtm/UnitTest_Define.f90.html#TEST_INCREMENT' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE Test_Increment( UnitTest ) 2,2
    TYPE(UnitTest_type), INTENT(IN OUT) :: UnitTest
    INTEGER :: n_Tests, n_AllTests
    
    CALL Get_Property( &amp;
      UnitTest, &amp;
      n_Tests    = n_Tests, &amp;
      n_AllTests = n_AllTests )
      
    n_Tests    = n_Tests    + 1
    n_AllTests = n_AllTests + 1
    
    CALL Set_Property( &amp;
      UnitTest, &amp;
      n_Tests    = n_Tests, &amp;
      n_AllTests = n_AllTests )
  END SUBROUTINE Test_Increment


!------------------------------------------------------------------------------
!
! NAME:
!       Display_Message
!
! PURPOSE:
!       Subroutine to display the unit test messages to stdout.
!
! CALLING SEQUENCE:
!       CALL Display_Message( UnitTest )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN OUT)
!
!------------------------------------------------------------------------------

<A NAME='DISPLAY_MESSAGE'><A href='../../html_code/crtm/UnitTest_Define.f90.html#DISPLAY_MESSAGE' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE Display_Message( UnitTest ) 757,4
    TYPE(UnitTest_type), INTENT(IN) :: UnitTest
    ! Variables
    INTEGER :: Level
    CHARACTER(SL) :: Procedure
    CHARACTER(SL) :: Message
    CHARACTER(SL) :: Fmt
    CHARACTER(SL) :: Prefix
    CHARACTER(SL) :: Test_Info
    INTEGER :: n_Spaces
    
    CALL Get_Property( &amp;
      UnitTest, &amp;
      Level = Level, &amp;
      Procedure = Procedure, &amp;
      Message = Message )
    
    ! Set output bits manually
    Test_Info = ''
    SELECT CASE(Level)
      CASE(INIT_LEVEL)
        Prefix = '/'
        n_Spaces = 1
      CASE(SETUP_LEVEL)
        Prefix = '/,3x,14("-"),/'
        n_Spaces = 3
      CASE(TEST_LEVEL)
        Prefix = ''
        n_Spaces = 5
        CALL Test_Info_String( UnitTest, Test_Info )
      CASE(REPORT_LEVEL)
        Prefix = ''
        n_Spaces = 3
      CASE(SUMMARY_LEVEL)
        Prefix = '/,1x,16("="),/'
        n_Spaces = 1
      CASE DEFAULT
        Prefix = '/,"INVALID MESSAGE LEVEL!!",/'
        n_Spaces = 15
    END SELECT
    
    ! Write the message to stdout
    WRITE(Fmt, '("(",a,i0,"x,a,"": "",a,1x,a)")') TRIM(Prefix), n_Spaces
    WRITE( *,FMT=Fmt ) TRIM(Procedure), TRIM(Test_Info), TRIM(Message)
    
  END SUBROUTINE Display_Message


!------------------------------------------------------------------------------
!
! NAME:
!       Test_Info_String
!
! PURPOSE:
!       Subroutine to construct an info string for message output.
!
! CALLING SEQUENCE:
!       CALL Test_Info_String( UnitTest, info )
!
! OBJECT:
!       UnitTest:      UnitTest object.
!                      UNITS:      N/A
!                      TYPE:       TYPE(UnitTest_type)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(IN)
!
! OUTPUTS:
!       info:          Character string containing the test number and
!                      whether the test passed or failed.
!                      UNITS:      N/A
!                      TYPE:       CHARACTER(*)
!                      DIMENSION:  Scalar
!                      ATTRIBUTES: INTENT(OUT)
!
!------------------------------------------------------------------------------

<A NAME='TEST_INFO_STRING'><A href='../../html_code/crtm/UnitTest_Define.f90.html#TEST_INFO_STRING' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

  SUBROUTINE Test_Info_String( UnitTest, info ) 2,1
    TYPE(UnitTest_Type), INTENT(IN) :: UnitTest
    CHARACTER(*), INTENT(OUT) :: info
    INTEGER :: n_Tests
    CHARACTER(6) :: PassFail
    CALL Get_Property( UnitTest, n_Tests = n_Tests )
    IF ( UnitTest_Passed( UnitTest ) ) THEN
      PassFail = 'PASSED'
    ELSE
      PassFail = 'FAILED'
    END IF
    WRITE( info,'("Test#",i0,1x,a,".")') n_Tests, PassFail
  END SUBROUTINE Test_Info_String


!====================
! UTILITY PROCEDURES
!====================

!------------------------------------------------------------------------------
!
! NAME:
!       Get_Multiplier
!
! PURPOSE:
!       Elemental function to compute the exponent multiplier of an input
!       for use in scaling tolerance values for floating point comparisons.
!
! CALLING SEQUENCE:
!       e = Get_Multiplier(x)
!
! INPUTS:
!       x:             Number for which the exponent multiplier is required.
!                      UNITS:      N/A
!                      TYPE:       REAL(Single)   , or
!                                  REAL(Double)
!                      DIMENSION:  Scalar or any rank
!                      ATTRIBUTES: INTENT(IN)
!
! FUNCTION RESULT:
!       e:             Exponent multiplier to use in scaling tolerance values.
!                      UNITS:      N/A
!                      TYPE:       Same as input x.
!                      DIMENSION:  Same as input x.
!
!------------------------------------------------------------------------------

<A NAME='REALSP_GET_MULTIPLIER'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALSP_GET_MULTIPLIER' TARGET='top_target'><IMG SRC="../../gif/bar_green.gif" border=0></A>

  ELEMENTAL FUNCTION realsp_get_multiplier(x) RESULT(e) 1
    REAL(Single), INTENT(IN) :: x
    REAL(Single) :: e
    IF (x &gt; 0.0_Single) THEN
      e = 10.0_Single**FLOOR(LOG10(x))
    ELSE
      e = 1.0_Single
    END IF
  END FUNCTION realsp_get_multiplier
  
<A NAME='REALDP_GET_MULTIPLIER'><A href='../../html_code/crtm/UnitTest_Define.f90.html#REALDP_GET_MULTIPLIER' TARGET='top_target'><IMG SRC="../../gif/bar_green.gif" border=0></A>

  ELEMENTAL FUNCTION realdp_get_multiplier(x) RESULT(e) 1
    REAL(Double), INTENT(IN) :: x
    REAL(Double) :: e
    IF (x &gt; 0.0_Double) THEN
      e = 10.0_Double**FLOOR(LOG10(x))
    ELSE
      e = 1.0_Double
    END IF
  END FUNCTION realdp_get_multiplier
  
END MODULE UnitTest_Define