;-------------------------------------------------------------
;+
; NAME:
; JD2YMD
; PURPOSE:
; Find year, month, day from julian day number.
; CATEGORY:
; CALLING SEQUENCE:
; jd2ymd, jd, y, m, d
; INPUTS:
; jd = Julian day number (like 2447000). in
; KEYWORD PARAMETERS:
; OUTPUTS:
; y = year (like 1987). out
; m = month number (like 7). out
; d = day of month (like 23). out
; COMMON BLOCKS:
; NOTES:
; MODIFICATION HISTORY:
; R. Sterner. 21 Aug, 1986.
; Johns Hopkins Applied Physics Lab.
; RES 18 Sep, 1989 --- converted to SUN
; R. Sterner, 30 Apr, 1993 --- cleaned up and allowed arrays.
; Theo Brauers, 21 Sep, 1997 long loop index i
;
; Copyright (C) 1986, Johns Hopkins University/Applied Physics Laboratory
; This software may be used, copied, or redistributed as long as it is not
; sold and this copyright notice is reproduced on each copy made. This
; routine is provided as is without any express or implied warranties
; whatsoever. Other limitations apply as described in the file disclaimer.txt.
;-
;-------------------------------------------------------------
pro jd2ymd, jdd, y, m, d, help=hlp
if (n_params(0) lt 4) or keyword_set(hlp) then begin
print,' Find year, month, day from julian day number.'
print,' jd2ymd, jd, y, m, d'
print,' jd = Julian day number (like 2447000). in'
print,' y = year (like 1987). out'
print,' m = month number (like 7). out'
print,' d = day of month (like 23). out'
return
endif
jd = long(jdd) ; Force long.
y = fix((jd - 1721029)/365.25) ; Estimated year.
jd0 = ymd2jd(y, 1, 0) ; JD for day 0.
days = jd - jd0 ; Day of year.
w = where(days le 0, cnt) ; Find where year is wrong.
if cnt gt 0 then begin
y[w] = y[w] - 1 ; Year was off by 1.
jd0[w] = ymd2jd( y[w], 1, 0) ; New JD for day 0.
days[w] = jd[w] - jd0[w] ; New day of year.
endif
;--- Correct for leap-years. -----
ly = (((y mod 4) eq 0) and ((y mod 100) ne 0)) $
or ((y mod 400) eq 0)
;--- Days before start of each month. -----
ydays = [0,0,31,59,90,120,151,181,212,243,273,304,334,366]
off = [0,0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
;---------------- Find which month. --------------------------
; Algorithm: ydays has cumulative # days up to start of each month
; (13 elements so month number may be used as an index).
; This number needs 1 added for Mar to Dec if it is a leap year.
; This is done by adding the offset, off, times the leap year flag.
; The larger the day of year (days) the fewer elements of this
; corrected ydays array will be greater than days. The
; entries in the corrected ydays gt days are located by where and
; counted by n_elements. Ydays has 13 elements so subtract result
; from 13 to get month number.
;---------------------------------------------------------------
njd = n_elements(jd) ; # of JDs to convert.
m = intarr(njd) ; Set up storage for months.
d = intarr(njd) ; Set up storage for day of month.
; T.B. i=0L (was i=0)
for i = 0L, njd-1 do begin ; Loop through each JD.
ydays2 = ydays+ly[i]*off ; Correct cumulative days for year.
dy = days[i] ; Days into year for i'th JD.
mn = 13-n_elements(where(dy le ydays2)) ; i'th month number.
m[i] = mn ; Store month.
d[i] = fix(dy - ydays2[mn]) ; Find and store i'th day of month.
endfor
;--------- Make sure scalars are returned as scalars -------
if n_elements(m) eq 1 then begin
m = m[0]
d = d[0]
endif
return
end