ホーア論理
From Wikipedia, the free encyclopedia
定義
部分的正当性(partial correctness)
事前条件(precondition) P が成り立つときに、プログラム S を実行して、それが停止した場合においては必ず事後条件(postcondition) Q が成り立つならば、プログラム S は、事前条件 P と事後条件 Q とに関して部分的に正当(partially correct)であると言い[3]、
- P { S } Q
と記述する[4]。ホーアによる元々の記法は上記のものであるが、一般的にはプログラム S の部分正当性は、
- { P } S { Q }
正当性(correctness)
事前条件 P が成り立つときに、プログラム S を実行すると、その実行が必ず終了するならば、プログラム S は、事前条件 P に関して停止する(terminate)と言う[3]。
プログラム S が部分的に正当かつ停止するものであるとき、すなわち、プログラム S が事前条件 P に関して停止し、停止後には必ず事後条件 Q が成り立つならば、プログラム S は、事前条件 P と事後条件 Q とに関して正当(correct)であるという[3]。
部分的正当性の証明体系
(A1) 代入文の公理
- { Q[e/x] }
x:=e{ Q }
ここで、事前条件の Q[e/x] は置換であり、式 Q の中に出現するすべての x を式 e で置き換えた式を表す。一方で事後条件の Q は代入文実行後(置換ではなく代入を行ったあとの)x の値について式 Q が成り立つことを表す[3]。
したがって、この公理は、
- { Q[e/x] }:式 Q 中の全ての x を e に置換するとき式 Q が成り立つのであれば、
x:=e:(置換で成り立つならば、ほぼ同じような代入操作でも変わらないはずのため)式 Q 中の x の値を代入 x:=e で変更することで、- { Q }:(置換の場合は成り立っているのであるから x の値が e に変更されたのであれば当然に)代入文実行後の式 Q は成り立つ、
というように読む[7]。
(A2) 空文の公理
空文(skip文)は、プログラムの状態を変化させないが、これを表すのが空文の公理である。skip以前に真であったことはそのまま真となる。
- { P } skip { P }
(R1) 複合文の規則
一般に順序的プログラムは機能ごとに分解することができるが、その逆として分解した手続きは複合文として合成することができる。以下の複合文の規則は分解したプログラムが中間条件 R を介することで元の機能に合成されることを表している[8]。
{ P } S1 { R } , { R } S2 { Q } | |
{ P } S1 ; S2 { Q } |
(R2) if文の規則
{ P ∧ B } S1 { Q } , { P ∧ ¬B } S2 { Q } | |
{ P } If B Then S1 else S2 End { Q } |
{ P ∧ B } S1 { Q } , P ∧ ¬B => Q | |
{ P } If B Then S1 End { Q } |
(R3) while文の規則
{ P ∧ B } S1 { P } | |
{ P } While B Do S1 End { P ∧ ¬B } |
(R4) 帰結の規則
P => P1 , { P1 } S { Q1 } , Q1 => Q | |
{ P } S { Q } |
例
例 1 (代入の公理) (結果規則) 例 2 (代入の公理) ( ここで x と N は整数型) (結果規則)