マヤ暦への変換
マヤ長期暦における時代(始まりの日付)をユリウス暦の日付として特定する.
In[1]:=
epoch = JulianDate["Modified",
DateObject[{-3114, 8, 11}, TimeZone -> 0]];
マヤ長期暦の単位をユリウス暦の日付に変換する関数を作る.
In[2]:=
JulianFromMayanLongCount[{baktun_, katun_, tun_, uinal_, kin_}] :=
epoch + 144000*baktun + 7200*katun + 360*tun + 20*uinal + kin
FromJulianDateを使って例の入力を判定することができる.
In[3]:=
example = JulianFromMayanLongCount[{7, 17, 18, 19, 2}]
Out[3]=
In[4]:=
FromJulianDate["Modified", example, TimeZone -> 0]
Out[4]=
マヤ長期暦からグレゴリオ暦の日付オブジェクトに直接変換する関数を作る.
In[5]:=
GregorianFromMayanLongCount[date_] := DateValue[
FromJulianDate["Modified",
JulianFromMayanLongCount[date],
TimeZone -> 0],
"Day",
DateObject]
In[6]:=
GregorianFromMayanLongCount[{7, 17, 18, 19, 2}]
Out[6]=
ユリウス暦の日付からマヤ長期暦の単位に変換する関数を作る.
In[7]:=
JulianToMayanLongCount[date_] := NumberDecompose[
Floor[date - epoch],
{144000, 7200, 360, 20, 1}
]
JulianDateを使って任意の日付入力をユリウス暦の日付として解釈することができる.解釈された日付はJulianToMayanLongCountの入力として使うことができる.
In[8]:=
DateToMayanLongCount[date_] := Block[{$TimeZone = 0},
JulianToMayanLongCount[JulianDate["Modified", date]]
]
この関数は,任意の入力日付を取って対応するマヤ長期暦の日付リストを返すようになった.
In[9]:=
DateToMayanLongCount["May 4th, 2015"]
Out[9]=
In[10]:=
DateToMayanLongCount[AbsoluteTime[]]
Out[10]=
In[11]:=
DateToMayanLongCount[Today]
Out[11]=
これら2つの関数を使って,マヤ長期暦との両方向の変換できるようになった.
In[12]:=
DateToMayanLongCount[{1900, 1, 1}]
Out[12]=
In[13]:=
DateToMayanLongCount[{1900, 1, 1}];
GregorianFromMayanLongCount[%]
Out[13]=