user_clock.F90 Source File


This file depends on

sourcefile~~user_clock.f90~2~~EfferentGraph sourcefile~user_clock.f90~2 user_clock.F90 sourcefile~parkind1.f90 parkind1.F90 sourcefile~user_clock.f90~2->sourcefile~parkind1.f90

Contents

Source Code


Source Code

SUBROUTINE USER_CLOCK(PELAPSED_TIME,PELAPSED_TIME_SINCE,PVECTOR_CP,PTOTAL_CP)

!**** *USER_CLOCK* - interface to system dependent timer routines

!     Purpose.
!     --------
!        Returns elapsed and CP from the start of execution.
!        Elapsed time is made relative to the first call to USER_CLOCK.

!**   Interface.
!     ----------
!        ZTIME=USER_CLOCK(PELAPSED_TIME,PELAPSED_TIME_SINCE,
!                         PVECTOR_CP,PTOTAL_CP)

!        Explicit arguments: (All are optional arguments)
!                           PELAPSED_TIME=wall clock time (seconds)
!                           PELAPSED_TIME_SINCE=wall clock time (seconds)
!                             change from input value of this parameter
!                           PVECTOR_CP=CP vector time  (seconds)
!                           PTOTAL_CP=total CP time   (seconds)

!     Author.
!     -------
!        D.Dent      *ECMWF*

!     External References:
!     -------------------

!        TIMEF,CPTIME

!     Modifications.
!     --------------
!        Original  : 97-09-25
!     ----------------------------------------------------------


USE PARKIND1  ,ONLY : JPIM     ,JPRB

IMPLICIT NONE

REAL(KIND=JPRB),INTENT(OUT) :: PELAPSED_TIME,PVECTOR_CP,PTOTAL_CP
REAL(KIND=JPRB),INTENT(INOUT) :: PELAPSED_TIME_SINCE
OPTIONAL            PELAPSED_TIME,PELAPSED_TIME_SINCE
OPTIONAL            PVECTOR_CP,PTOTAL_CP
REAL(KIND=JPRB)      :: ZVECTOR_CP,ZTOTAL_CP,ZWALL
REAL(KIND=JPRB),EXTERNAL :: TIMEF


! === END OF INTERFACE BLOCK ===
IF(PRESENT(PELAPSED_TIME).OR. PRESENT(PELAPSED_TIME_SINCE)) THEN

  ZWALL=TIMEF()
!             TIMEF returns milliseconds since first call to TIMEF
  IF(PRESENT(PELAPSED_TIME)) THEN
    PELAPSED_TIME=ZWALL*1.0E-3_JPRB
  ENDIF
  IF(PRESENT(PELAPSED_TIME_SINCE)) THEN
    PELAPSED_TIME_SINCE=ZWALL*1.0E-3_JPRB - PELAPSED_TIME_SINCE
  ENDIF
ENDIF

IF( PRESENT(PVECTOR_CP) .OR. PRESENT(PTOTAL_CP) ) THEN
  CALL CPTIME(ZVECTOR_CP,ZTOTAL_CP)
ENDIF
IF( PRESENT(PVECTOR_CP) ) THEN
  PVECTOR_CP=ZVECTOR_CP
ENDIF
IF( PRESENT(PTOTAL_CP) ) THEN
  PTOTAL_CP=ZTOTAL_CP
ENDIF

RETURN
END SUBROUTINE USER_CLOCK