Convert hours, minutes, seconds to days.
Status: support routine.
If the s argument is a string, only the leftmost character is used and no warning status is provided.
The result is computed even if any of the range checks fail.
Negative IHOUR, IMIN and/or SEC produce a warning status, but the absolute value is used in the conversion.
If there are multiple errors, the status value reflects only the first, the smallest taking precedence.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
character(len=1), | intent(in) | :: | s | sign: '-' = negative, otherwise positive |
||
integer, | intent(in) | :: | ihour | hours |
||
integer, | intent(in) | :: | imin | minutes |
||
real(kind=wp), | intent(in) | :: | sec | seconds |
||
real(kind=wp), | intent(out) | :: | days | interval in days |
||
integer, | intent(out) | :: | j |
|
subroutine TF2D ( s, ihour, imin, sec, days, j )
implicit none
character(len=1),intent(in) :: s !! sign: '-' = negative, otherwise positive
integer,intent(in) :: ihour !! hours
integer,intent(in) :: imin !! minutes
real(wp),intent(in) :: sec !! seconds
real(wp),intent(out) :: days !! interval in days
integer,intent(out) :: j !! status:
!! * 0 = OK
!! * 1 = IHOUR outside range 0-23
!! * 2 = IMIN outside range 0-59
!! * 3 = SEC outside range 0-59.999...
real(wp) :: w
! Preset the status.
j = 0
! Validate seconds, minutes, hours.
if ( sec<0.0_wp .or. sec>=60.0_wp ) j=3
if ( imin<0 .or. imin>59 ) j=2
if ( ihour<0 .or. ihour>23 ) j=1
! Compute the interval.
w = ( 60.0_wp * ( 60.0_wp * real( abs(ihour), wp ) + &
real( abs(imin), wp ) ) + &
abs(sec) ) / d2s
! Apply the sign.
if ( s == '-' ) w = -w
! Return the result.
days = w
end subroutine TF2D