Очень простой код умножения:
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 != m*n, но я не могу понять.
res != m*n
, скорее это означает, что Дафни не может доказать, чтоres == m*n
во всех случаях. Вот почему он говорит, что может не держаться. - person lexicalscope   schedule 20.09.2016