A非常に単純な乗算コードで混乱:Dafny事後条件メッセージ
method Product1 (m: nat, n: nat) returns (res:nat)
ensures res == m * n;
{
var m1: nat := 0;
var n1: nat := 0;
res := 0;
while (m1 < m)
{
n1 := 0;
while (n1 < n)
{
res := res + 1;
n1 := n1 + 1;
}
m1 := m1 + 1;
}
}
は、私はdafnyでそれを確認すると、それは言う:
Description Line Column
1 A postcondition might not hold on this return path. 8 4
2 This is the postcondition that might not hold. 2 16
私はそれを言う得るいくつかの条件、RES =メートル下に! * nしかし、私はそれを把握することはできません。
また、行番号を数えるように人々に依頼しないでください。違反行にコメントを追加する。 – CandiedOrange
事後条件メッセージは '' 'res!= m * n''を意味するのではなく、Dafnyがすべての場合に' 'res == m * n''を証明できないことを意味します。それは、「可能かもしれない」と言われている理由です。 – lexicalscope