feat(normalizer): Easter computus

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
Marcel
2026-05-25 13:21:39 +02:00
parent 8f6f4f2d62
commit c6cceec6e9
2 changed files with 30 additions and 0 deletions

View File

@@ -0,0 +1,21 @@
"""Tolerant historical date parsing for the family archive."""
import datetime
def easter(year: int) -> datetime.date:
"""Easter Sunday (Gregorian) via the Anonymous Gregorian / Butcher algorithm."""
a = year % 19
b = year // 100
c = year % 100
d = b // 4
e = b % 4
f = (b + 8) // 25
g = (b - f + 1) // 3
h = (19 * a + b - d - g + 15) % 30
i = c // 4
k = c % 4
l = (32 + 2 * e + 2 * i - h - k) % 7
m = (a + 11 * h + 22 * l) // 451
month = (h + l - 7 * m + 114) // 31
day = ((h + l - 7 * m + 114) % 31) + 1
return datetime.date(year, month, day)

View File

@@ -0,0 +1,9 @@
import datetime
import dates
def test_easter_known_years():
# Anonymous Gregorian algorithm — verified against published tables
assert dates.easter(2024) == datetime.date(2024, 3, 31)
assert dates.easter(2000) == datetime.date(2000, 4, 23)
assert dates.easter(1922) == datetime.date(1922, 4, 16)
assert dates.easter(1888) == datetime.date(1888, 4, 1)