Accéder au contenu principal

Calculer la date de Pâques pour n’importe quelle année

Établie au concile de Nicée en 325, la date officielle du dimanche de Pâques sert de référence pour fixer les dates de plusieurs jours fériés. En France, il y a le lundi de Pâques (i.e. le lendemain), le jeudi de l’Ascension (39 jours après) et le lundi de Pentecôte (50 jours après) ; aux États-Unis, le Good Friday tombe le vendredi qui précède le dimanche de Pâques (soit deux jours avant). Problème : calculer la date de Pâques est affreusement compliqué.

Fort heureusement, quelques brillants esprits s'y sont collés avant nous et nous ont livré des algorithmes capables de déterminer cette date précisément, sans avoir recours aux redoutables méthodes canoniques que je vous laisse découvrir par vos propres moyens. Je vous propose ci-dessous la méthode dite de Butcher [1] codée sous R : elle permet, pour n’importe quelle année, de trouver la date du dimanche de Pâques dans le calendrier Grégorien.

EasterSunday = function(year) {
 a <- year%%19
 b <- floor(year/100)
 c <- year%%100
 d <- (19*a+b-floor(b/4)-floor((b-floor((b+8)/25)+1)/3)+15)%%30
 e <- (32+2*(b%%4)+2*floor(c/4)-d-c%%4)%%7
 f <- floor((a+11*d+22*e)/451)
 month <- floor((d+e-7*f+114)/31)
 day <- (d+e-7*f+114)%%31+1
 Date(year, month, day)
}

Notez que la fonction Date utilisée ci-dessus est aussi de moi. Voici le code :

Date = function(year, month, day) {
 m <- formatC(month, width = 2, flag = "0")
 d <- formatC(day, width = 2, flag = "0")
 as.Date(paste(year, m, d, sep = "-"))
}

Vous pouvez ainsi vérifier que :

> EasterSunday(2017)
[1] "2017-04-16"
>

Elle fonctionne aussi avec des vecteurs :

> EasterSunday(1515:1518)
[1] "1515-04-11" "1516-04-02" "1517-04-22" "1518-04-07"
> 

For English-speaking readers: this is an R function to compute the date of Easter Sunday in the Gregorian calendar for any given year using Butcher’s algorithm.

---
[1] Cet algorithme a été publié en 1876 par un auteur inconnu dans Nature ; C'est donc Samuel Butcher, évêque de Meath qui a démontré qu’elle est exacte en 1877, qui lui donne son nom.

Commentaires

Posts les plus consultés de ce blog

Brandolini’s law

Over the last few weeks, this picture has been circulating on the Internet. According to RationalWiki, that sentence must be attributed to Alberto Brandolini, an Italian independent software development consultant [1]. I’ve checked with Alberto and, unless someone else claims paternity of this absolutely brilliant statement, it seems that he actually is the original author. Here is what seems to be the very first appearance of what must, from now on, be known as the Brandolini’s law (or, as Alberto suggests, the Bullshit Asymmetry Principle):The bullshit asimmetry: the amount of energy needed to refute bullshit is an order of magnitude bigger than to produce it.— ziobrando (@ziobrando) 11 Janvier 2013To be sure, a number of people have made similar statements. Ironically, it seems that the “a lie can travel halfway around the world while the truth is still putting on its shoes” quote isn’t from Mark Twain but a slightly modified version of Charles Spurgeon’s “a lie will go round the w…

Culture et détente

Cher Monsieur Dubouchon [1],Ainsi donc, vous appelez Lacordaire à la rescousse en me rappelant qu’« entre le fort et le faible, entre le riche et le pauvre, entre le maître et le serviteur, c'est la liberté qui opprime, et la loi qui affranchit. »Au risque de vous surprendre et de vous déplaire encore un peu plus : vous n’êtes pas le premier. Cette citation du Révérend-Père, voilà des années que tout ce que la toile compte d’antilibéraux primaires nous la sert, dans sa forme longue, dans sa forme abrégée ou dans une forme plus ou moins modifiée selon les circonstances. À titre personnel, elle m’a été jetée au visage par des communistes hilares, par des socialistes révolutionnaires, par des sociaux-démocrates inquiets, par des conservateurs en un seul mot, par des souverainistes indignés, par des nationaux-socialistes hésitants et même par un catholique décroissant.Je ne sais pas vraiment où vous classer dans cet inventaire – nous nous connaissons si peu – mais vous m’avez suffisam…

Comment j’ai déprogrammé l’obsolescence

C’est arrivé ce matin. Notre lave-vaisselle familial, que nous avions programmé pour tourner la nuit dernière, n’avait pas fonctionné. Mon épouse, étonnée par cette inhabituelle défaillance, a essayé de le relancer : rien à faire, le bestiau ne fonctionnait plus. Dépités, nous convînmes donc, ma dulcinée et moi-même, qu’il était temps de lui trouver un remplaçant. Cette fois ci, nous disions nous pas plus tard que ce matin, nous n’achèterons pas la première camelote venue à 300 euros : rendez-vous fût pris en début de soirée pour faire l’acquisition d’une bête de course qui, nous l’espérions, durerait vingt ans, comme celle de belle-maman.Dans les entrailles de la bêteMais la journée avançant, cette histoire ne sortait pas de ma tête. Le lave-vaisselle en question, nous l’avions tout de même acheté il y a à peine plus de trois ans : ce n’est pas Dieu possible que ce machin, même s’il ne nous avait objectivement pas coûté grand-chose, nous lâche aussi vite. Si ça se trouve, me disais-j…