Files
why3/examples/dijkstra/why3session.xml
2025-01-14 19:48:35 +01:00

266 lines
14 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.11.2" timelimit="1" steplimit="0" memlimit="1000"/>
<prover id="1" name="Alt-Ergo" version="2.5.4" timelimit="5" steplimit="0" memlimit="1000"/>
<prover id="2" name="CVC4" version="1.6" timelimit="1" steplimit="0" memlimit="1000"/>
<prover id="3" name="Alt-Ergo" version="2.6.0" timelimit="1" steplimit="0" memlimit="1000"/>
<file format="whyml" proved="true">
<path name=".."/><path name="dijkstra.mlw"/>
<theory name="DijkstraShortestPath" proved="true">
<goal name="relax&#39;vc" expl="VC for relax" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="13283"/></proof>
</goal>
<goal name="Length_nonneg" proved="true">
<transf name="induction_pr" proved="true" >
<goal name="Length_nonneg.0" proved="true">
<proof prover="2"><result status="valid" time="0.020000" steps="5021"/></proof>
</goal>
<goal name="Length_nonneg.1" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="9672"/></proof>
</goal>
</transf>
</goal>
<goal name="Path_inversion" proved="true">
<proof prover="2"><result status="valid" time="0.040000" steps="8860"/></proof>
</goal>
<goal name="Path_shortest_path" proved="true">
<transf name="introduce_premises" proved="true" >
<goal name="Path_shortest_path.0" proved="true">
<transf name="induction" proved="true" arg1="d">
<goal name="Path_shortest_path.0.0" expl="base case" proved="true">
<proof prover="2"><result status="valid" time="0.020000" steps="7054"/></proof>
</goal>
<goal name="Path_shortest_path.0.1" expl="recursive case" proved="true">
<proof prover="2"><result status="valid" time="0.060000" steps="14531"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="Main_lemma" proved="true">
<proof prover="2"><result status="valid" time="0.140000" steps="21428"/></proof>
</goal>
<goal name="Completeness_lemma" proved="true">
<transf name="induction_pr" proved="true" >
<goal name="Completeness_lemma.0" proved="true">
<proof prover="2"><result status="valid" time="0.020000" steps="9206"/></proof>
</goal>
<goal name="Completeness_lemma.1" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="10220"/></proof>
</goal>
</transf>
</goal>
<goal name="inside_or_exit" proved="true">
<transf name="induction_pr" proved="true" >
<goal name="inside_or_exit.0" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="9643"/></proof>
</goal>
<goal name="inside_or_exit.1" proved="true">
<proof prover="2"><result status="valid" time="0.140000" steps="38312"/></proof>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.0" expl="loop invariant init" proved="true">
<transf name="unfold" proved="true" arg1="inv">
<goal name="shortest_path_code&#39;vc.0.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.0.0.0" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.060000" steps="12056"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.1" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.010000" steps="41"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.2" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="12640"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.3" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.060000" steps="12763"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.4" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="11291"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.5" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="11409"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.0.0.6" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.080000" steps="70"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.1" expl="loop invariant init" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="13257"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.2" expl="loop invariant init" proved="true">
<proof prover="2"><result status="valid" time="0.100000" steps="14705"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.3" expl="precondition" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="11645"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.4" expl="assertion" proved="true">
<proof prover="2"><result status="valid" time="0.080000" steps="17638"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.5" expl="loop invariant init" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="13605"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6" expl="loop invariant init" proved="true">
<transf name="unfold" proved="true" arg1="inv">
<goal name="shortest_path_code&#39;vc.6.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.6.0.0" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.020000" steps="180"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.1" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.040000" steps="13736"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.2" expl="VC for shortest_path_code" proved="true">
<transf name="unfold" proved="true" arg1="subset">
<goal name="shortest_path_code&#39;vc.6.0.2.0" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.180000" steps="17044"/></proof>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.3" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.020000" steps="177"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.4" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="16339"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.5" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.070000" steps="251"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.6.0.6" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.110000" steps="16218"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.7" expl="loop invariant init" proved="true">
<transf name="unfold" proved="true" arg1="inv_succ2">
<goal name="shortest_path_code&#39;vc.7.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.7.0.0" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.090000" steps="22810"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.7.0.1" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.060000" steps="592"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.8" expl="precondition" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="13259"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.9" expl="assertion" proved="true">
<transf name="destruct" proved="true" arg1="Ensures">
<goal name="shortest_path_code&#39;vc.9.0" expl="assertion" proved="true">
<proof prover="0"><result status="valid" time="0.040000" steps="194242"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.9.1" expl="assertion" proved="true">
<proof prover="3"><result status="valid" time="0.050000" steps="541"/></proof>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.10" expl="loop variant decrease" proved="true">
<proof prover="2"><result status="valid" time="0.100000" steps="17886"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.11" expl="loop invariant preservation" proved="true">
<proof prover="2"><result status="valid" time="0.080000" steps="18125"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12" expl="loop invariant preservation" proved="true">
<transf name="unfold" proved="true" arg1="inv">
<goal name="shortest_path_code&#39;vc.12.0" expl="VC for shortest_path_code" proved="true">
<transf name="unfold" proved="true" arg1="inv" arg2="in" arg3="LoopInvariant2">
<goal name="shortest_path_code&#39;vc.12.0.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.12.0.0.0" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.070000" steps="19197"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.1" expl="VC for shortest_path_code" proved="true">
<transf name="case" proved="true" arg1="(v=src)">
<goal name="shortest_path_code&#39;vc.12.0.0.1.0" expl="true case" proved="true">
<proof prover="2"><result status="valid" time="0.240000" steps="33769"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.1.1" expl="false case" proved="true">
<proof prover="3"><result status="valid" time="0.070000" steps="576"/></proof>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.2" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.040000" steps="13821"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.3" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.250000" steps="33247"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.4" expl="VC for shortest_path_code" proved="true">
<proof prover="2"><result status="valid" time="0.050000" steps="15325"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.5" expl="VC for shortest_path_code" proved="true">
<proof prover="3"><result status="valid" time="0.090000" steps="733"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.6" expl="VC for shortest_path_code" proved="true">
<transf name="case" proved="true" arg1="(v=v1)">
<goal name="shortest_path_code&#39;vc.12.0.0.6.0" expl="true case" proved="true">
<proof prover="1"><result status="valid" time="0.478677" steps="7089"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.12.0.0.6.1" expl="false case" proved="true">
<proof prover="3"><result status="valid" time="0.137070" steps="2091"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.13" expl="loop invariant preservation" proved="true">
<transf name="unfold" proved="true" arg1="inv_succ2">
<goal name="shortest_path_code&#39;vc.13.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_vc" proved="true" >
<goal name="shortest_path_code&#39;vc.13.0.0" expl="VC for shortest_path_code" proved="true">
<transf name="split_all_full" proved="true" >
<goal name="shortest_path_code&#39;vc.13.0.0.0" expl="VC for shortest_path_code" proved="true">
<proof prover="2" timelimit="10" memlimit="4000"><result status="valid" time="0.200000" steps="39681"/></proof>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.13.0.1" expl="VC for shortest_path_code" proved="true">
<proof prover="3" timelimit="5"><result status="valid" time="0.270505" steps="4221"/></proof>
</goal>
</transf>
</goal>
</transf>
</goal>
<goal name="shortest_path_code&#39;vc.14" expl="loop variant decrease" proved="true">
<proof prover="2"><result status="valid" time="0.150000" steps="20060"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.15" expl="loop invariant preservation" proved="true">
<proof prover="2"><result status="valid" time="0.030000" steps="13257"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.16" expl="loop invariant preservation" proved="true">
<proof prover="2"><result status="valid" time="0.160000" steps="22426"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.17" expl="loop invariant preservation" proved="true">
<proof prover="0"><result status="valid" time="0.360000" steps="561164"/></proof>
<proof prover="3"><result status="valid" time="0.483272" steps="4759"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.18" expl="postcondition" proved="true">
<proof prover="2"><result status="valid" time="0.060000" steps="14069"/></proof>
</goal>
<goal name="shortest_path_code&#39;vc.19" expl="postcondition" proved="true">
<proof prover="2"><result status="valid" time="0.410000" steps="45046"/></proof>
</goal>
</transf>
</goal>
</theory>
</file>
</why3session>