Loop Convergence Proofs in KeYmaera X
This is a brief tutorial on implementing loop convergence proofs in KeYmaera X. I’ll assume you already know all about loop variants and just want to get started using this proof technique in KeYmaera X / dynamic logic.
I’ll use a very simple theorem as the running example:
x < 0 -> <{x:=x+1;}*>x>0
Intuitively, the formula states that if x<0
initially, then after repeating x := x + 1
some number of times, we find a state where x>0
.
Proving this property requires finding a loop variant j(v)
and using this variant together with the
loop convergence proof rule:
data:image/s3,"s3://crabby-images/d778a/d778a5221cbda555fee4692b1cb3a6abca35ab1e" alt="The Loop Convergence proof rule in differential dynamic logic"
For this model, the loop variant x = -v + 1
is sufficient. To use the proof rule with this loop variant,
click on the web form and enter the variant in the web form. You might get a warning message:
data:image/s3,"s3://crabby-images/78c3d/78c3d012da48c0a64e35dace8d996fe4aa1a2396" alt="The Loop Convergence proof rule in differential dynamic logic -- warning message"
You can ignore this warning message by clicking anywhere outside of the warning message box. Then, click on the proof rule to execute the loop convergence proof step:
data:image/s3,"s3://crabby-images/c9cff/c9cff658036f14c6e6c08941f8f27fe5ea632008" alt="The Loop Convergence proof rule in differential dynamic logic -- ignoring the warning message"
Alternatively, you can simply type the
con({`x=-v+1`}, 1)
tactic into the tactic editor box:
data:image/s3,"s3://crabby-images/3c6db/3c6dba89b0d1e1e3e59da2c014391534fa62622f" alt="The Loop Convergence proof rule in differential dynamic logic -- using con({`j(v)`}, 1) from the tactic editor"
You’ll now have three goals, two of which are arithmetic and one of which requires a single
application of assignd
(diamond assign axiom) before cosing.
The final tactic:
implyR(1) ; con({`x=-v+1`}, 1) ; <(
QE
,
assignd(1) ; QE
,
QE
)