Files
why3/examples/cursor_examples/why3session.xml
2024-01-31 13:02:13 +00:00

153 lines
7.4 KiB
XML

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE why3session PUBLIC "-//Why3//proof session v5//EN"
"https://www.why3.org/why3session.dtd">
<why3session shape_version="6">
<prover id="0" name="Z3" version="4.12.2" timelimit="5" steplimit="0" memlimit="1000"/>
<prover id="4" name="Alt-Ergo" version="2.0.0" timelimit="5" steplimit="0" memlimit="1000"/>
<prover id="5" name="CVC4" version="1.5" timelimit="5" steplimit="0" memlimit="1000"/>
<file format="whyml" proved="true">
<path name=".."/><path name="cursor_examples.mlw"/>
<theory name="TestCursor" proved="true">
<goal name="sum&#39;vc" expl="VC for sum" proved="true">
<proof prover="4"><result status="valid" time="2.860000" steps="903"/></proof>
</goal>
</theory>
<theory name="ListCursorImpl&#39;impl" proved="true">
<goal name="cursor&#39;vc" expl="VC for cursor" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="33"/></proof>
</goal>
<goal name="snoc_Cons&#39;vc" expl="VC for snoc_Cons" proved="true">
<proof prover="4"><result status="valid" time="0.030000" steps="99"/></proof>
</goal>
<goal name="C.next&#39;vc" expl="VC for next" proved="true">
<proof prover="4"><result status="valid" time="0.100000" steps="476"/></proof>
</goal>
<goal name="C.has_next&#39;vc" expl="VC for has_next" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="66"/></proof>
</goal>
<goal name="create&#39;vc" expl="VC for create" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="53"/></proof>
</goal>
<goal name="ListCursor&#39;impl_of.create&#39;refn&#39;vc" expl="VC for create&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="35"/></proof>
</goal>
<goal name="ListCursor&#39;impl_of.C.next&#39;refn&#39;vc" expl="VC for next&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="68"/></proof>
</goal>
<goal name="ListCursor&#39;impl_of.C.has_next&#39;refn&#39;vc" expl="VC for has_next&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="13"/></proof>
</goal>
</theory>
<theory name="TestListCursor" proved="true">
<goal name="sum_of_list" proved="true">
<transf name="induction_ty_lex" proved="true" >
<goal name="sum_of_list.0" proved="true">
<transf name="split_goal_right" proved="true" >
<goal name="sum_of_list.0.0" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="19"/></proof>
</goal>
<goal name="sum_of_list.0.1" proved="true">
<proof prover="4"><result status="valid" time="3.390000" steps="1177"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="list_sum&#39;vc" expl="VC for list_sum" proved="true">
<transf name="split_goal_right" proved="true" >
<goal name="list_sum&#39;vc.0" expl="loop invariant init" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="18"/></proof>
</goal>
<goal name="list_sum&#39;vc.1" expl="loop invariant init" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="6"/></proof>
</goal>
<goal name="list_sum&#39;vc.2" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="8"/></proof>
</goal>
<goal name="list_sum&#39;vc.3" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.000000" steps="2"/></proof>
</goal>
<goal name="list_sum&#39;vc.4" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="9"/></proof>
</goal>
<goal name="list_sum&#39;vc.5" expl="loop variant decrease" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="28"/></proof>
</goal>
<goal name="list_sum&#39;vc.6" expl="loop invariant preservation" proved="true">
<transf name="simplify_trivial_quantification" proved="true" >
<goal name="list_sum&#39;vc.6.0" expl="loop invariant preservation" proved="true">
<proof prover="4"><result status="valid" time="4.570000" steps="1495"/></proof>
</goal>
</transf>
</goal>
<goal name="list_sum&#39;vc.7" expl="loop invariant preservation" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="14"/></proof>
</goal>
<goal name="list_sum&#39;vc.8" expl="postcondition" proved="true">
<proof prover="4"><result status="valid" time="1.060000" steps="343"/></proof>
</goal>
</transf>
</goal>
</theory>
<theory name="ArrayCursorImpl&#39;impl" proved="true">
<goal name="cursor&#39;vc" expl="VC for cursor" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="3"/></proof>
</goal>
<goal name="create&#39;vc" expl="VC for create" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="5"/></proof>
</goal>
<goal name="C.has_next&#39;vc" expl="VC for has_next" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="19"/></proof>
</goal>
<goal name="C.next&#39;vc" expl="VC for next" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="75"/></proof>
</goal>
<goal name="ArrayCursor&#39;impl_of.create&#39;refn&#39;vc" expl="VC for create&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="29"/></proof>
</goal>
<goal name="ArrayCursor&#39;impl_of.C.next&#39;refn&#39;vc" expl="VC for next&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="46"/></proof>
</goal>
<goal name="ArrayCursor&#39;impl_of.C.has_next&#39;refn&#39;vc" expl="VC for has_next&#39;refn" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="13"/></proof>
</goal>
</theory>
<theory name="TestArrayCursor" proved="true">
<goal name="array_sum&#39;vc" expl="VC for array_sum" proved="true">
<transf name="split_goal_right" proved="true" >
<goal name="array_sum&#39;vc.0" expl="loop invariant init" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="17"/></proof>
</goal>
<goal name="array_sum&#39;vc.1" expl="loop invariant init" proved="true">
<proof prover="0"><result status="valid" time="0.040000" steps="87290"/></proof>
</goal>
<goal name="array_sum&#39;vc.2" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="7"/></proof>
</goal>
<goal name="array_sum&#39;vc.3" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="1"/></proof>
</goal>
<goal name="array_sum&#39;vc.4" expl="precondition" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="8"/></proof>
</goal>
<goal name="array_sum&#39;vc.5" expl="loop variant decrease" proved="true">
<proof prover="4"><result status="valid" time="0.010000" steps="25"/></proof>
</goal>
<goal name="array_sum&#39;vc.6" expl="loop invariant preservation" proved="true">
<proof prover="4"><result status="valid" time="2.970000" steps="1085"/></proof>
</goal>
<goal name="array_sum&#39;vc.7" expl="loop invariant preservation" proved="true">
<proof prover="4"><result status="valid" time="0.020000" steps="13"/></proof>
</goal>
<goal name="array_sum&#39;vc.8" expl="postcondition" proved="true">
<proof prover="4"><result status="valid" time="0.880000" steps="374"/></proof>
</goal>
</transf>
</goal>
<goal name="harness1&#39;vc" expl="VC for harness1" proved="true">
<proof prover="5"><result status="valid" time="0.160000" steps="25758"/></proof>
</goal>
</theory>
</file>
</why3session>