Большое и большое спасибо заранее!
Следующий фрагмент кода представляет собой функцию, которая дает мне год, месяц и день для данного юлианского дня.
Подскажите, пожалуйста, что означают константы здесь? Я могу найти этот код по всей сети, но никто не объясняет значения по умолчанию, взятые здесь. Также, если кто-то может объяснить, что будет делать функция.
Предположим, что значение, которое я передаю для JD, равно 2456447 ..
VOID GetGregorianDate(LONG JD, PWORD Year, PWORD Month, PWORD Day)
{
LONG j, y, d, m;
j = JD - 1721119; //what is this value - 1721119 (may be related to day.. but how ?)
y = (4 * j - 1) / 146097; //what is this value - 146097 (may be related to year.. but how ?)
j = 4 * j - 1 - 146097 * y;
d = j / 4;
j = (4 * d + 3) / 1461; // ?
d = 4 * d + 3 - 1461 * j;
d = (d + 4) / 4;
m = (5 * d - 3) / 153; // ?
d = 5 * d - 3 - 153 * m;
d = (d + 5) / 5;
y = 100 * y + j;
if (m < 10)
{
m = m + 3;
}
else
{
m = m - 9;
y = y + 1;
}
*Year = (WORD) y;
*Month = (WORD) m;
*Day = (WORD) d;
}
Это просто артефакты григорианского календаря и произвольной даты, выбранной в качестве начала юлианской эпохи.
Непростая арифметика складывает их все вместе, чтобы дать правильное количество дней, принимая во внимание високосные годы и различную продолжительность месяца.
Эта бумага (ссылка с Википедия) описывает, как возникают различные магические числа в обратном расчете (от григорианской даты до юлианского дня); числа в вашем алгоритме возникают аналогичным образом.
Других решений пока нет …