1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
<?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="Alt-Ergo" version="2.4.1" timelimit="5" steplimit="0" memlimit="1000"/>
<prover id="2" name="Alt-Ergo" version="2.2.0" timelimit="5" steplimit="0" memlimit="2000"/>
<prover id="3" name="CVC4" version="1.6" timelimit="1" steplimit="0" memlimit="1000"/>
<file format="whyml" proved="true">
<path name=".."/><path name="tree_of_array.mlw"/>
<theory name="TreeOfArray" proved="true">
<goal name="tree_of_array_aux'vc" expl="VC for tree_of_array_aux" proved="true">
<transf name="split_vc" proved="true" >
<goal name="tree_of_array_aux'vc.0" expl="precondition" proved="true">
<proof prover="3"><result status="valid" time="0.030000" steps="7092"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.1" expl="variant decrease" proved="true">
<proof prover="3"><result status="valid" time="0.070000" steps="10149"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.2" expl="precondition" proved="true">
<proof prover="3"><result status="valid" time="0.060000" steps="9844"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.3" expl="variant decrease" proved="true">
<proof prover="3"><result status="valid" time="0.040000" steps="11824"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.4" expl="precondition" proved="true">
<proof prover="3"><result status="valid" time="0.100000" steps="16256"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.5" expl="index in array bounds" proved="true">
<proof prover="3"><result status="valid" time="0.070000" steps="12919"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6" expl="postcondition" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="tree_of_array_aux'vc.6.0" expl="VC for tree_of_array_aux" proved="true">
<proof prover="2" timelimit="1" memlimit="1000"><result status="valid" time="0.020000" steps="45"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6.1" expl="VC for tree_of_array_aux" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="tree_of_array_aux'vc.6.1.0" expl="VC for tree_of_array_aux" proved="true">
<proof prover="2"><result status="valid" time="0.310000" steps="583"/></proof>
</goal>
</transf>
</goal>
<goal name="tree_of_array_aux'vc.6.2" expl="VC for tree_of_array_aux" proved="true">
<transf name="case" proved="true" arg1="hi=lo">
<goal name="tree_of_array_aux'vc.6.2.0" expl="true case" proved="true">
<proof prover="3"><result status="valid" time="0.040000" steps="11860"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6.2.1" expl="false case" proved="true">
<transf name="case" proved="true" arg1="hi=lo+1">
<goal name="tree_of_array_aux'vc.6.2.1.0" expl="false case (true case)" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="tree_of_array_aux'vc.6.2.1.0.0" expl="false case (true case)" proved="true">
<proof prover="0"><result status="valid" time="0.320000" steps="3559"/></proof>
</goal>
</transf>
</goal>
<goal name="tree_of_array_aux'vc.6.2.1.1" expl="false case" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="tree_of_array_aux'vc.6.2.1.1.0" expl="false case" proved="true">
<proof prover="2"><result status="valid" time="0.810000" steps="928"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="tree_of_array_aux'vc.6.3" expl="VC for tree_of_array_aux" proved="true">
<transf name="case" proved="true" arg1="hi=lo">
<goal name="tree_of_array_aux'vc.6.3.0" expl="true case" proved="true">
<proof prover="3"><result status="valid" time="0.040000" steps="11860"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6.3.1" expl="false case" proved="true">
<transf name="case" proved="true" arg1="hi=lo+1">
<goal name="tree_of_array_aux'vc.6.3.1.0" expl="false case (true case)" proved="true">
<transf name="assert" proved="true" arg1="left=Empty">
<goal name="tree_of_array_aux'vc.6.3.1.0.0" expl="asserted formula" proved="true">
<proof prover="3"><result status="valid" time="0.080000" steps="15295"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6.3.1.0.1" expl="false case (true case)" proved="true">
<transf name="assert" proved="true" arg1="right=Empty">
<goal name="tree_of_array_aux'vc.6.3.1.0.1.0" expl="asserted formula" proved="true">
<proof prover="3"><result status="valid" time="0.060000" steps="15298"/></proof>
</goal>
<goal name="tree_of_array_aux'vc.6.3.1.0.1.1" expl="false case (true case)" proved="true">
<proof prover="2" timelimit="1" memlimit="1000"><result status="valid" time="0.030000" steps="105"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="tree_of_array_aux'vc.6.3.1.1" expl="false case" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="tree_of_array_aux'vc.6.3.1.1.0" expl="false case" proved="true">
<proof prover="2"><result status="valid" time="2.060000" steps="1103"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="tree_of_array'vc" expl="VC for tree_of_array" proved="true">
<proof prover="3"><result status="valid" time="0.040000" steps="8692"/></proof>
</goal>
</theory>
</file>
</why3session>
|