Hoarelogica

Hoarelogica is een formele logica die in de informatica wordt gebruikt om over programma's te redeneren. Ze is vernoemd naar de bedenker van de basis van het mechanisme, Tony Hoare.

Hoaretripels en correctheid

Hoarelogica is een toepassing van de predicatencalculus op de ontwikkeling van programma's. De logica werd in 1969 door Tony Hoare in het artikel An axiomatic basis for computer programming geïntroduceerd. Aan de basis van de hoarelogica staat het hoaretripel:

{ P }   S   { Q } {\displaystyle \{P\}\ S\ \{Q\}} ,

waarin P {\displaystyle P} en Q {\displaystyle Q} predicatenlogische formules zijn die een verzameling toestanden beschrijven en S {\displaystyle S} één of meer instructies is. Het hoaretripel { P }   S   { Q } {\displaystyle \{P\}\ S\ \{Q\}} betekent, dat als een programma zich in een toestand bevindt waarin de conditie P {\displaystyle P} (de preconditie) geldt, en S {\displaystyle S} wordt uitgevoerd, het programma zich daarna in een toestand zal bevinden waarin de conditie Q {\displaystyle Q} (de postconditie) geldt.

Een hoaretripel { P }   S   { Q } {\displaystyle \{P\}\ S\ \{Q\}} is partieel correct wanneer het volgende geldt: als P {\displaystyle P} waar is in de huidige toestand, en S {\displaystyle S} wordt uitgevoerd, dan geldt in de toestand die optreedt nadat S {\displaystyle S} uitgevoerd is, Q {\displaystyle Q} . Het kan zijn dat S {\displaystyle S} nooit termineert, omdat S {\displaystyle S} in een oneindige lus terechtkomt ( S {\displaystyle S} termineert dan niet). In dat geval bestaat er geen toestand na het uitvoeren van S {\displaystyle S} , en kan Q {\displaystyle Q} dus een willekeurige formule zijn.

Een hoaretripel { P }   S   { Q } {\displaystyle \{P\}\ S\ \{Q\}} is volledig correct als hij partieel correct is en S {\displaystyle S} altijd termineert.

Bewijsregels van de hoarelogica

De hoarelogica bevat bewijsregels waarmee het mogelijk is partiële of volledige correctheid van een hoaretripel te bewijzen. In de oorspronkelijke bewijsregels werd een eenvoudige, sequentiële programmeertaal gebruikt, maar inmiddels zijn door anderen al vele uitbreidingen op de logica bedacht. Voor een eenvoudige programmeertaal die bestaat uit variabelen, toekenningen, voorwaardelijke sprongen (if then else) en lussen (while B do) bestaat de hoarelogica waarmee partiële correctheid kan worden bewezen uit de volgende bewijsregels (voor volledige correctheid is daarnaast een bewijs nodig, dat het programma altijd termineert):

Toekenningsaxioma

Met het toekenningsaxioma kan geredeneerd worden over variabeletoekenningen.

{ P [ x f ] }   x := f   { P } {\displaystyle \{P[x\backslash f]\}\ x{\mathrel {:=}}f\ \{P\}}

Hier staat P [ x f ] {\displaystyle P[x\backslash f]} voor de formule P {\displaystyle P} waarin alle voorkomens van de variabele x {\displaystyle x} worden vervangen door f {\displaystyle f} . Met dit axioma kan bijvoorbeeld worden bewezen dat het hoaretripel { y > 5 }   x := y   { x > 5 } {\displaystyle \{y>5\}\ x:=y\ \{x>5\}} correct is.

Gevolgtrekkingsregel

Met de gevolgtrekkingsregel kan de preconditie van een hoaretripel worden versterkt of de postconditie verzwakt:

P P { P }   S   { Q } Q Q { P }   S   { Q } {\displaystyle {\frac {P'\to P\quad \{P\}\ S\ \{Q\}\quad Q\to Q'}{\{P'\}\ S\ \{Q'\}}}}

Compositieregel

Met de compositieregel kan worden geredeneerd over programma's die uit meer dan een opdracht bestaan.

{ P }   S   { Q } { Q }   T   { R } { P }   S ; T   { R } {\displaystyle {\frac {\{P\}\ S\ \{Q\}\quad \{Q\}\ T\ \{R\}}{\{P\}\ S\mathop {;} T\ \{R\}}}}

Iteratieregel

Met de iteratieregel kan worden geredeneerd over lussen.

{ P B }   S   { P } { P }   while  B  do  S   { P ¬ B } {\displaystyle {\frac {\{P\land B\}\ S\ \{P\}}{\{P\}\ {\mbox{while }}B{\mbox{ do }}S\ \{P\land \lnot B\}}}}

In de bovenstaande regel is B {\displaystyle B} de lusvoorwaarde: als de lus termineert, dan is B {\displaystyle B} niet meer waar. De formule P {\displaystyle P} is een lusinvariant, een formule die altijd waar is net voordat en net nadat S {\displaystyle S} uitgevoerd wordt.

Keuzeregel

Met de keuzeregel wordt geredeneerd over if-then-else-opdrachten.

{ P B }   S   { Q } { P ¬ B }   T   { Q } { P }   if  B  then  S  else  T   { Q } {\displaystyle {\frac {\{P\land B\}\ S\ \{Q\}\quad \{P\land \neg B\}\ T\ \{Q\}}{\{P\}\ {\mbox{if }}B{\mbox{ then }}S{\mbox{ else }}T\ \{Q\}}}}

Zwakste precondities

Een bijdrage uit 1975 aan de hoarelogica, van Edsger W. Dijkstra, was het geven van zwakste precondities. De zwakste preconditie van een formule Q {\displaystyle Q} met betrekking tot een programma S {\displaystyle S} , geschreven w p ( S , Q ) {\displaystyle {\mathit {wp}}(S,Q)} , is de zwakste conditie P {\displaystyle P} (de conditie waar de grootste verzameling programmatoestanden aan voldoet) zodat { P } S { Q } {\displaystyle \{P\}S\{Q\}} een volledig correcte hoaretripel is (dat wil onder andere zeggen, das S {\displaystyle S} termineert).

De zwakste preconditie kan als volgt worden uitgerekend:

  • Toekenning:
w p ( x := f , Q ) = Q [ x f ] {\displaystyle {\mathit {wp}}(x:=f,Q)=Q[x\backslash f]}
  • Sequentiële compositie:
w p ( S ; T , Q ) = w p ( S , w p ( T , Q ) ) {\displaystyle {\mathit {wp}}(S\mathop {;} T,Q)={\mathit {wp}}(S,{\mathit {wp}}(T,Q))}
  • Keuze:
w p ( if  B  then  S  else  T , Q ) = ( B w p ( S , Q ) ) ( ¬ B w p ( T , Q ) ) {\displaystyle {\mathit {wp}}({\text{if }}B{\text{ then }}S{\text{ else }}T,Q)=(B\to {\mathit {wp}}(S,Q))\land (\neg B\to {\mathit {wp}}(T,Q))}
  • Iteratie:
w p ( while  B  do  S , Q ) = k H k {\displaystyle {\mathit {wp}}({\text{while }}B{\text{ do }}S,Q)=\exists k\,H_{k}}
waarbij
  • H 0 = ¬ E Q {\displaystyle H_{0}=\neg E\land Q}
  • H k + 1 = H 0 w p ( S , H k ) {\displaystyle H_{k+1}=H_{0}\lor {\mathit {wp}}(S,H_{k})}
Hierbij is H k {\displaystyle H_{k}} inductief gedefinieerd.

Literatuur

  • C.A.R. Hoare. An axiomatic basis for computer programming (pdf). In: Communications of the ACM. 12(10): 576–585, 1969.
  • W.H.J. Feijen en A.J.M. van Gasteren. On a method of multiprogramming. Springer Verlag, 1999.
  • E.W. Dijkstra en C.S. Scholten. Predicate calculus and program semantics. Springer Verlag, 1990.