WikiDer > Сравнение Зеллерса - Википедия
Конгруэнтность Целлера является алгоритм разработан Кристиан Зеллер к рассчитать день недели для любого Юлиан или же Григорианский календарь Дата. Его можно считать основанным на преобразовании между Юлианский день и календарная дата.
Формула
Для григорианского календаря сравнение Целлера
для юлианского календаря это
куда
- час это день недели (0 = суббота, 1 = воскресенье, 2 = понедельник, ..., 6 = пятница)
- q это день месяца
- м это месяц (3 = март, 4 = апрель, 5 = май, ..., 14 = февраль)
- K год века ().
- J это с нуля век (на самом деле Например, отсчитываемые от нуля столетия для 1995 и 2000 годов равны соответственно 19 и 20 (не путать с обычным порядковым перечислением столетий, которое указывает 20-е в обоих случаях).
- это функция пола или целая часть
- мод это операция по модулю или остаток после деления
ПРИМЕЧАНИЕ: В этом алгоритме январь и февраль считаются месяцами 13 и 14 предыдущего года. Например. если это 2 февраля 2010 г., алгоритм считает дату вторым днем четырнадцатого месяца 2009 г. (14.02.2009 в формате ДД / ММ / ГГГГ)
Для Дата недели ISO День недели d (1 = с понедельника по 7 = воскресенье), используйте
Реализация в программном обеспечении
Формулы основаны на математическом определении по модулю деление, что означает, что −2 mod 7 равно положительному 5. К сожалению, большинство компьютерных языков реализует функцию остатка, −2 mod 7 возвращает результат −2. Итак, чтобы реализовать сравнение Целлера на компьютере, формулы следует немного изменить, чтобы числитель был положительным. Самый простой способ сделать это - заменить − 2J к + 5J и − J к + 6J. Итак, формулы становятся:
по григорианскому календарю и
по юлианскому календарю.
Нетрудно увидеть, что в данном году 1 марта (если это суббота, то 2 марта) является хорошей датой проверки; и что в данном столетии лучший тестовый год - это год, кратный 100.
Зеллер использовал десятичную арифметику, и ей было удобно пользоваться J и K в представлении года. Но при использовании компьютера проще обрабатывать измененный год. Y, который Y - 1 в январе и феврале:
для григорианского календаря (в этом случае нет возможности переполнения, потому что ), и
по юлианскому календарю.
Анализ
Эти формулы основаны на наблюдении, что день недели изменяется предсказуемым образом на основе каждой части этой даты. Каждый член формулы используется для вычисления смещения, необходимого для получения правильного дня недели.
Таким образом, для григорианского календаря различные части этой формулы можно понимать следующим образом:
- представляет прогрессию дня недели в зависимости от дня месяца, так как каждый последующий день приводит к дополнительному смещению 1 в день недели.
- представляет собой изменение дня недели в зависимости от года. Предполагая, что каждый год длится 365 дней, одна и та же дата в каждом последующем году будет компенсирована значением .
- Поскольку в каждом високосном году 366 дней, это необходимо учесть, добавив еще один день к значению смещения дня недели. Это достигается добавлением в зачет. Этот член рассчитывается как целочисленный результат. Любой остаток отбрасывается.
- Используя аналогичную логику, прогрессию дня недели для каждого столетия можно рассчитать, заметив, что в нормальном столетии 36524 дня и 36525 дней в каждом столетии, которые делятся на 400. Поскольку и , период, термин : учитывает это (снова используя целочисленное деление и отбрасывая дробный остаток). Чтобы избежать отрицательных чисел, этот термин можно заменить на: с эквивалентными результатами.
- Период, термин который также можно заменить на подстраивается под изменение дней месяца. Начиная с января дни в месяце: {31, 28/29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}. Дни 28 или 29 февраля являются проблемой, поэтому формула переносит январь и февраль до конца, поэтому короткий счет февраля не вызовет проблемы. Формула интересуется днями недели, поэтому числа в последовательности можно брать по модулю 7. Тогда количество дней в месяце по модулю 7 (все еще начиная с января) будет {3, 0/1, 3, 2 , 3, 2, 3, 3, 2, 3, 2, 3}. Начиная с марта, последовательность в основном чередуется 3, 2, 3, 2, 3, но каждые пять месяцев подряд идут два 31-дневных месяца (июль – август и декабрь – январь).[1] Дробь 13/5 = 2,6 и функция пола имеют этот эффект; знаменатель 5 устанавливает период в 5 месяцев.
- Общая функция, , нормализует результат, чтобы он находился в диапазоне от 0 до 6, что дает индекс правильного дня недели для анализируемой даты.
Причина, по которой формула отличается для юлианского календаря, заключается в том, что в этом календаре нет отдельного правила для високосных столетий и он смещен от григорианского календаря на фиксированное количество дней в каждом столетии.
Поскольку григорианский календарь был принят в разное время в разных регионах мира, местоположение события имеет большое значение для определения правильного дня недели для даты, которая произошла в течение этого переходного периода. Это требуется только до 1929 года, поскольку это был последний год, когда юлианский календарь все еще использовался какой-либо страной на Земле, и поэтому не требуется для 1930 года или позже.
Формулы можно использовать proleptically, но с осторожностью в течение многих лет до года нашей эры 1, потому что реализация операторов по модулю и евклидова деления может усекать целые числа в неправильном направлении (потолок вместо пола). Чтобы учесть это, можно добавить достаточное число, кратное 400 грегорианским или 700 юлианским годам, и вычесть 1 для чисел года до нашей эры («Год 0» на самом деле является годом 1 до н.э. по юлианскому календарю). На самом деле они придерживаются прозорливости вплоть до 1 марта 4 г. н.э. из-за плохого управления в Риме (но не в Египте) в период с момента введения календаря в действие 1 января 45 г. до н. Э. (Который не был високосным).
Примеры
Для 1 января 2000 года датой будет считаться 13-й месяц 1999 года, поэтому значения будут следующими:
Таким образом, формула оценивается как .
(36 происходит от , усеченное до целого числа.)
Однако для 1 марта 2000 года датой считается 3-й месяц 2000 года, поэтому значения становятся
поэтому формула оценивается как .
Смотрите также
Рекомендации
- ^ Правило каждых пяти месяцев применяется только к двенадцати месяцам в году, начинающимся 1 марта и заканчивающимся в последний день следующего февраля.
Библиография
В каждом из этих четырех похожих листов с изображениями, во-первых, рассматривается день недели, а во-вторых, дата пасхального воскресенья для юлианского и григорианского календарей. На страницах есть ссылки на переводы на английский язык.
- Целлер, Кристиан (1882). "Die Grundaufgaben der Kalenderrechnung auf neue und vereinfachte Weise gelöst". Württembergische Vierteljahrshefte für Landesgeschichte (на немецком). V: 313–314. Архивировано из оригинал 11 января 2015 года.
- Целлер, Кристиан (1883). «Проблема дуплекса Calendarii Fundmentale». Bulletin de la Société Mathématique de France (на латыни). 11: 59–61. Архивировано из оригинал 11 января 2015 года.
- Целлер, Кристиан (1885). «Календер-Формельн». Mathematisch-naturwissenschaftliche Mitteilungen des Mathematisch-naturwissenschaftlichen Vereins в Вюртемберге (на немецком). 1 (1): 54–58. Архивировано из оригинал 11 января 2015 года.
- Целлер, Кристиан (1886). «Календер-Формельн». Acta Mathematica (на немецком). 9: 131–136. Дои:10.1007 / BF02406733. Архивировано из оригинал 10 января 2015 г.
внешняя ссылка
- Календарные работы Rektor Chr. Целлер: формулы дня недели и пасхи Дж. Р. Стоктон, недалеко от Лондона, Великобритания. Сайт включает изображения и переводы четырех вышеуказанных статей, а также справочной карты Зеллера «Das Ganze der Kalender-Rechnung».
- Эта статья включает материалы общественного достояния отNIST документ:Блэк, Пол Э. «Конгруэнтность Целлера». Словарь алгоритмов и структур данных.