À la question
Comment s’appelait le Président de la République Française en mai 1968 ?
Alice répond :
« Charles de Gaulle ayant été élu Président le 8 janvier 1959 et ayant démissionné le 28 avril 1969 (après avoir été réélu en 1965) était donc encore en fonction en mai 1968. D’ailleurs on se souvient de la fermeté dont il avait fait preuve alors. Le Président de la République Française s’appelait donc Charles de Gaulle en mai 1968. »
Bob, lui, répond à la même question :
« Le Président de la République Française s’appelle Nicolas Sarközy de Nagy-Bosca. Il est né le 28 janvier 1955 et avait donc 13 ans en 1968. Il a d’ailleurs pris part à un mouvement de lycéens à l’époque. Il s’appelait déjà Nicolas Sarközy de Nagy-Bosca en mai 1968. En mai 1968, le Président de la République Française s’appelait donc Nicolas Sarközy de Nagy-Bosca. »
Qui a raison ?
Exemple d’une boucle
On va considérer le script ci-dessous, qui calcule la somme des entiers consécutifs jusqu’à 5 :
Voici une simulation en mode pas-à-pas, où le temps
est piloté par un curseur situé en bas de la figure (La ligne en cours d’exécution est coloriée en rouge, et on a abrégé « indice=indice+1 » en « indice++ ») :
Au temps
, les deux variables
et
sont indéfinies. Au temps
, la proposition
est vraie (effet de l’initialisation), et le reste tant que
: Après ça, quand
,
est vraie et donc
ne l’est plus !
Histoire d’avoir une notation, comme il est d’usage d’écrire
juste pour dire que
est vraie (et
si
est fausse), notons
le fait que
est vraie au temps
(c’est-à-dire lorsque
). Cela suppose que le temps est discret [1].
Par exemple, la proposition
est vraie aux temps
et
mais pas avant ni après :
![]()
mais
![]()
et
![]()
Au prochain top
La logique temporelle est une logique modale, ce qui veut dire que non seulement une proposition
peut être vraie ou fausse, mais qu’elle a plusieurs manières d’être vraie (par exemple, dans le futur ou dans le passé).
Le plus simple des opérateurs modaux de la logique temporelle est noté
et signifie « vrai au prochain top » (donc là encore, le temps est supposé discret et mesuré par des entiers naturels). Si l’intervalle de mesure du temps est le jour,
signifie « vrai le lendemain ».
Dans l’exemple de l’onglet précédent, on a
puisque ![]()
puisque ![]()
mais
puisque ![]()
Plus généralement on a
|
|
Axiomes
L’opérateur
obéit aux axiomes suivants :
(ce qui ne sera pas vrai demain, sera faux demain) ;
(s’il pleut et vente demain, alors il pleuvra demain, et il y aura du vent demain) ;
(s’il pleut ou vente demain, alors ou bien il pleuvra demain, ou bien il y aura du vent demain).
Le certain et l’éternel
Toutes ces choses qui sont vraies seulement à certains moments mais pas tous, c’est bien compliqué. La logique temporelle s’intéresse beaucoup plus à ce qui est tout le temps vrai, avec ça au moins on est en terrain stable...
On note donc
le fait que
est vrai mais aussi le restera toujours.
On a donc
mais aussi
.
D’ailleurs
peut être défini récursivement par
|
|
(que
soit destiné à être toujours vrai à partir de maintenant, signifie que
est vrai et que son statut sera le même demain).
L’opérateur modal « toujours » (
) obéit aux axiomes suivants :

(l’éternité est éternelle)
(si une implication et sa prémisse sont toujours vrais alors sa conclusion l’est aussi)
(si chaque fois que
est vrai, il le reste le lendemain, alors dès que
est vrai c’est pour toujours : C’est le principe de récurrence).
Il ne faut jamais dire jamais
Au lieu de noter le fait que
n’est jamais vrai par
on a aussi une notation duale :
où
veut dire que
sera vrai au moins une fois dans le futur («
est inéluctable »).
Alors
et
(l’inéluctable, c’est le pas toujours faux).
Une propriété dont on souhaite très fort qu’elle soit inéluctable en algorithmique, c’est l’arrêt d’un algorithme.
L’opérateur
obéit à ces axiomes :



(ce qui est inéluctable, est inéluctablement inéluctable : On dirait du Pierre Dac...)
Qui a raison ?
En notant
le prédicat « est président » et
le prédicat « a pour nom », on a
![]()
![]()
La première interprétation est celle d’Alice, la seconde celle de Bob : La différence entre les deux est le prédicat sur lequel porte la propriété « en 1968 ».

:
Commentaires