日付ベクトルをRのユリウス日に変換する
16Jun10という形式の日付の列があり、ユリウス日を抽出したいと思います。いろいろな年があります。
関数julianとmdy.dateを試してみましたが、機能していないようです。
以下を試して、クラスcharacter
(つまりテキスト)をクラスPOSIXlt
に変換し、ユリウス日(yday
)を抽出します。
tmp <- as.POSIXlt("16Jun10", format = "%d%b%y")
tmp$yday
# [1] 166
機能設定の詳細については:
?POSIXlt
?DateTimeClasses
もう1つのオプションは、Date
クラスを使用し、次にformat
を使用してジュリアンの日を抽出することです(このクラスは、POSIXltが0:365である間、ジュリアンの日を1:366で定義することに注意してください)。
tmp <- as.Date("16Jun10", format = "%d%b%y")
format(tmp, "%j")
# [1] "167"
同様に:
require(lubridate)
x = as.Date('2010-06-10')
yday(x)
[1] 161
また、lubridateを使用することに注意してください。
> dmy('16Jun10')
[1] "2010-06-16 UTC"
Rのinsol
パッケージには、POSIXctをユリウス日番号(JDN)に変換するJD(x, inverse=FALSE)
関数が含まれています。
insol
パッケージには、カスタム日付用のJDymd(year,month,day,hour=12,minute=0,sec=0)
もあります。
ユリウス日(JD)全体を表示するには、おそらくoptions(digits=16)
を設定する必要があります。
my.data = read.table(text = "
OBS MONTH1 DAY1 YEAR1
1 3 1 2012
2 3 31 2012
3 4 1 2012
4 4 30 2012
5 5 1 2012
6 5 31 2012
7 6 1 2012
8 6 30 2012
9 7 1 2012
10 7 31 2012
", header = TRUE, stringsAsFactors = FALSE)
my.data$MY.DATE1 <- do.call(paste, list(my.data$MONTH1, my.data$DAY1, my.data$YEAR1))
my.data$MY.DATE1 <- as.Date(my.data$MY.DATE1, format=c("%m %d %Y"))
my.data$my.julian.date <- as.numeric(format(my.data$MY.DATE1, "%j"))
my.data
戻り値。ユリウス日付は毎年1月の最初の日に1に戻らないため、技術的には正しくありません。
http://en.wikipedia.org/wiki/Julian_day
以下の日付は序数です。
OBS MONTH1 DAY1 YEAR1 MY.DATE1 my.julian.date
1 1 3 1 2012 2012-03-01 61
2 2 3 31 2012 2012-03-31 91
3 3 4 1 2012 2012-04-01 92
4 4 4 30 2012 2012-04-30 121
5 5 5 1 2012 2012-05-01 122
6 6 5 31 2012 2012-05-31 152
7 7 6 1 2012 2012-06-01 153
8 8 6 30 2012 2012-06-30 182
9 9 7 1 2012 2012-07-01 183
10 10 7 31 2012 2012-07-31 213
これは、元々APLで記述され、Jに変換されたコードのRバージョンです。これは、1582年10月15日以降の日付のみを対象としています。これは、西暦世界の一部の地域で、カレンダーの改革が任意に変更されたときの日付です。日付。
#* toJulian: convert 3-element c(Y,M,D) timestamp into pseudo-Julian day number.
toJulian<- function(TS3)
{ mm<- TS3[2]
xx<- 0
if( mm<=2) {xx<- 1}
mm<- (12*xx)+mm
yy<- TS3[1]-xx
nc<- floor(0.01*yy)
jd<- floor(365.25*yy)+floor(30.6001*(1+mm))+TS3[3]+1720995+(2-(nc-floor(0.25*nc)))
return(jd)
#EG toJulian c(1959,5,24) -> 2436713
#EG toJulian c(1992,12,16) -> 2448973
}
これは逆関数です:
#* toGregorian: convert pseudo-Julian day number to timestamp in form c(Y,M,D)
# (>15 Oct 1582). Adapted from "Numerical Recipes in C" by Press,
# Teukolsky, et al.
toGregorian<- function(jdn)
{ igreg<- 2299161 # Gregorian calendar conversion day c(1582,10,15).
ja<- floor(jdn)
xx<- 0
if(igreg<=ja){xx<- 1}
jalpha<- floor((floor((xx*ja)-1867216)-0.25)/36524.25)
ja<- ((1-xx)*ja) + ((xx*ja)+1+jalpha-floor(0.25*jalpha))
jb<- ja+1524
jc<- floor(6680+((jb-2439870)-122.1)/365.25)
jd<- floor(365.25*jc)
je<- floor((jb-jd)/30.6001)
id<- floor((jb-jd)-floor(30.6001*je))
mm<- floor(je-1)
if(12<mm){mm<- mm-12}
iyyy<- floor(jc-4715)
if(mm>2){iyyy<- iyyy-1}
if(0>iyyy){iyyy<- iyyy-1}
Gd<- c(iyyy, mm, id)
return(Gd)
#EG toGregorian 2436713 -> c(1959,5,24)
#EG toGregorian 2448973 -> c(1992,12,16)
}