|
1 | 1 | \profile "Java Profile"; |
2 | 2 |
|
3 | 3 | \settings { |
4 | | -"#Proof-Settings-Config-File |
5 | | -#Wed Apr 12 13:28:59 CEST 2023 |
6 | | -[NewSMT]NoTypeHierarchy=false |
7 | | -[Labels]UseOriginLabels=true |
8 | | -[StrategyProperty]QUERYAXIOM_OPTIONS_KEY=QUERYAXIOM_ON |
9 | | -[NewSMT]Presburger=false |
10 | | -[SMTSettings]invariantForall=false |
11 | | -[Strategy]ActiveStrategy=JavaCardDLStrategy |
12 | | -[StrategyProperty]USER_TACLETS_OPTIONS_KEY1=USER_TACLETS_OFF |
13 | | -[StrategyProperty]QUANTIFIERS_OPTIONS_KEY=QUANTIFIERS_NON_SPLITTING_WITH_PROGS |
14 | | -[StrategyProperty]USER_TACLETS_OPTIONS_KEY2=USER_TACLETS_OFF |
15 | | -[Choice]DefaultChoices=JavaCard-JavaCard\\:on, Strings-Strings\\:on, assertions-assertions\\:safe, bigint-bigint\\:on, finalFields-finalFields\\:immutable, floatRules-floatRules\\:strictfpOnly, initialisation-initialisation\\:disableStaticInitialisation, intRules-intRules\\:arithmeticSemanticsIgnoringOF, integerSimplificationRules-integerSimplificationRules\\:full, javaLoopTreatment-javaLoopTreatment\\:efficient, mergeGenerateIsWeakeningGoal-mergeGenerateIsWeakeningGoal\\:off, methodExpansion-methodExpansion\\:modularOnly, modelFields-modelFields\\:treatAsAxiom, moreSeqRules-moreSeqRules\\:on, permissions-permissions\\:off, programRules-programRules\\:Java, reach-reach\\:on, runtimeExceptions-runtimeExceptions\\:ban, sequences-sequences\\:on, wdChecks-wdChecks\\:off, wdOperator-wdOperator\\:L |
16 | | -[StrategyProperty]LOOP_OPTIONS_KEY=LOOP_SCOPE_INV_TACLET |
17 | | -[StrategyProperty]INF_FLOW_CHECK_PROPERTY=INF_FLOW_CHECK_FALSE |
18 | | -[SMTSettings]UseBuiltUniqueness=false |
19 | | -[SMTSettings]explicitTypeHierarchy=false |
20 | | -[SMTSettings]instantiateHierarchyAssumptions=true |
21 | | -[StrategyProperty]NON_LIN_ARITH_OPTIONS_KEY=NON_LIN_ARITH_DEF_OPS |
22 | | -[SMTSettings]SelectedTaclets= |
23 | | -[StrategyProperty]DEP_OPTIONS_KEY=DEP_ON |
24 | | -[StrategyProperty]AUTO_INDUCTION_OPTIONS_KEY=AUTO_INDUCTION_OFF |
25 | | -[Strategy]MaximumNumberOfAutomaticApplications=10000 |
26 | | -[StrategyProperty]STOPMODE_OPTIONS_KEY=STOPMODE_DEFAULT |
27 | | -[StrategyProperty]CLASS_AXIOM_OPTIONS_KEY=CLASS_AXIOM_DELAYED |
28 | | -[SMTSettings]useConstantsForBigOrSmallIntegers=true |
29 | | -[StrategyProperty]MPS_OPTIONS_KEY=MPS_MERGE |
30 | | -[StrategyProperty]SYMBOLIC_EXECUTION_NON_EXECUTION_BRANCH_HIDING_OPTIONS_KEY=SYMBOLIC_EXECUTION_NON_EXECUTION_BRANCH_HIDING_OFF |
31 | | -[Strategy]Timeout=-1 |
32 | | -[StrategyProperty]SYMBOLIC_EXECUTION_ALIAS_CHECK_OPTIONS_KEY=SYMBOLIC_EXECUTION_ALIAS_CHECK_NEVER |
33 | | -[StrategyProperty]QUERY_NEW_OPTIONS_KEY=QUERY_OFF |
34 | | -[SMTSettings]useUninterpretedMultiplication=true |
35 | | -[NewSMT]sqrtSMTTranslation=SMT |
36 | | -[StrategyProperty]BLOCK_OPTIONS_KEY=BLOCK_CONTRACT_INTERNAL |
37 | | -[StrategyProperty]METHOD_OPTIONS_KEY=METHOD_CONTRACT |
38 | | -[StrategyProperty]USER_TACLETS_OPTIONS_KEY3=USER_TACLETS_OFF |
39 | | -[NewSMT]identifier=OPEN |
40 | | -[SMTSettings]maxGenericSorts=2 |
41 | | -[StrategyProperty]OSS_OPTIONS_KEY=OSS_ON |
42 | | -[NewSMT]Axiomatisations=false |
43 | | -[StrategyProperty]SPLITTING_OPTIONS_KEY=SPLITTING_DELAYED |
44 | | -[SMTSettings]integersMinimum=-2147483645 |
45 | | -[StrategyProperty]VBT_PHASE=VBT_SYM_EX |
46 | | -[SMTSettings]integersMaximum=2147483645 |
47 | | -" |
48 | | -} |
| 4 | + "Choice" : { |
| 5 | + "JavaCard" : "JavaCard:on", |
| 6 | + "Strings" : "Strings:on", |
| 7 | + "assertions" : "assertions:safe", |
| 8 | + "bigint" : "bigint:on", |
| 9 | + "finalFields" : "finalFields:immutable", |
| 10 | + "floatRules" : "floatRules:strictfpOnly", |
| 11 | + "initialisation" : "initialisation:disableStaticInitialisation", |
| 12 | + "intRules" : "intRules:arithmeticSemanticsIgnoringOF", |
| 13 | + "integerSimplificationRules" : "integerSimplificationRules:full", |
| 14 | + "javaLoopTreatment" : "javaLoopTreatment:efficient", |
| 15 | + "mergeGenerateIsWeakeningGoal" : "mergeGenerateIsWeakeningGoal:off", |
| 16 | + "methodExpansion" : "methodExpansion:modularOnly", |
| 17 | + "modelFields" : "modelFields:treatAsAxiom", |
| 18 | + "moreSeqRules" : "moreSeqRules:on", |
| 19 | + "permissions" : "permissions:off", |
| 20 | + "programRules" : "programRules:Java", |
| 21 | + "reach" : "reach:on", |
| 22 | + "runtimeExceptions" : "runtimeExceptions:ban", |
| 23 | + "sequences" : "sequences:on", |
| 24 | + "soundDefaultContracts" : "soundDefaultContracts:on", |
| 25 | + "wdChecks" : "wdChecks:off", |
| 26 | + "wdOperator" : "wdOperator:L" |
| 27 | + }, |
| 28 | + "Labels" : { |
| 29 | + "UseOriginLabels" : true |
| 30 | + }, |
| 31 | + "NewSMT" : { |
| 32 | + "Axiomatisations" : "false", |
| 33 | + "NoTypeHierarchy" : "false", |
| 34 | + "Presburger" : "false", |
| 35 | + "identifier" : "OPEN", |
| 36 | + "sqrtSMTTranslation" : "SMT" |
| 37 | + }, |
| 38 | + "SMTSettings" : { |
| 39 | + "SelectedTaclets" : [ |
| 40 | + |
| 41 | + ], |
| 42 | + "UseBuiltUniqueness" : false, |
| 43 | + "explicitTypeHierarchy" : false, |
| 44 | + "instantiateHierarchyAssumptions" : true, |
| 45 | + "integersMaximum" : 2147483645, |
| 46 | + "integersMinimum" : -2147483645, |
| 47 | + "invariantForall" : false, |
| 48 | + "maxGenericSorts" : 2, |
| 49 | + "useConstantsForBigOrSmallIntegers" : true, |
| 50 | + "useUninterpretedMultiplication" : true |
| 51 | + }, |
| 52 | + "Strategy" : { |
| 53 | + "ActiveStrategy" : "Modular JavaDL Strategy", |
| 54 | + "MaximumNumberOfAutomaticApplications" : 10000, |
| 55 | + "Timeout" : -1, |
| 56 | + "options" : { |
| 57 | + "AUTO_INDUCTION_OPTIONS_KEY" : "AUTO_INDUCTION_OFF", |
| 58 | + "BLOCK_OPTIONS_KEY" : "BLOCK_CONTRACT_INTERNAL", |
| 59 | + "CLASS_AXIOM_OPTIONS_KEY" : "CLASS_AXIOM_DELAYED", |
| 60 | + "DEP_OPTIONS_KEY" : "DEP_ON", |
| 61 | + "LOOP_OPTIONS_KEY" : "LOOP_SCOPE_INV_TACLET", |
| 62 | + "METHOD_OPTIONS_KEY" : "METHOD_CONTRACT", |
| 63 | + "MPS_OPTIONS_KEY" : "MPS_MERGE", |
| 64 | + "NON_LIN_ARITH_OPTIONS_KEY" : "NON_LIN_ARITH_DEF_OPS", |
| 65 | + "OSS_OPTIONS_KEY" : "OSS_ON", |
| 66 | + "QUANTIFIERS_OPTIONS_KEY" : "QUANTIFIERS_NON_SPLITTING_WITH_PROGS", |
| 67 | + "QUERYAXIOM_OPTIONS_KEY" : "QUERYAXIOM_ON", |
| 68 | + "QUERY_NEW_OPTIONS_KEY" : "QUERY_OFF", |
| 69 | + "SPLITTING_OPTIONS_KEY" : "SPLITTING_DELAYED", |
| 70 | + "STOPMODE_OPTIONS_KEY" : "STOPMODE_DEFAULT", |
| 71 | + "SYMBOLIC_EXECUTION_ALIAS_CHECK_OPTIONS_KEY" : "SYMBOLIC_EXECUTION_ALIAS_CHECK_NEVER", |
| 72 | + "SYMBOLIC_EXECUTION_NON_EXECUTION_BRANCH_HIDING_OPTIONS_KEY" : "SYMBOLIC_EXECUTION_NON_EXECUTION_BRANCH_HIDING_OFF", |
| 73 | + "USER_TACLETS_OPTIONS_KEY1" : "USER_TACLETS_OFF", |
| 74 | + "USER_TACLETS_OPTIONS_KEY2" : "USER_TACLETS_OFF", |
| 75 | + "USER_TACLETS_OPTIONS_KEY3" : "USER_TACLETS_OFF", |
| 76 | + "VBT_PHASE" : "VBT_SYM_EX" |
| 77 | + } |
| 78 | + } |
| 79 | +} |
| 80 | + |
49 | 81 |
|
50 | | -\proofObligation { |
51 | | - "name": "disjointArrayRangeAllFields1", |
52 | | - "class": "de.uka.ilkd.key.taclettranslation.lemma.TacletProofObligationInput", |
53 | | - } |
| 82 | + |
| 83 | +\proofObligation |
| 84 | +// |
| 85 | +{ |
| 86 | + "class" : "de.uka.ilkd.key.taclettranslation.lemma.TacletProofObligationInput", |
| 87 | + "name" : "disjointArrayRangeAllFields1" |
| 88 | +} |
54 | 89 |
|
55 | 90 | \proof { |
56 | 91 | (keyLog "0" (keyUser "Julian" ) (keyVersion "80a871ca3bac8bb405ecc216fcb6fa9ef6f8a395")) |
| 92 | +(keyLog "1" (keyUser "weigl" ) (keyVersion "1df32008ebda9fe2684e1a5eb5e44bdd4c398d8f")) |
| 93 | +(keyLog "2" (keyUser "weigl" ) (keyVersion "1df32008ebda9fe2684e1a5eb5e44bdd4c398d8f")) |
57 | 94 |
|
58 | | -(autoModeTime "0") |
| 95 | +(autoModeTime "15") |
59 | 96 |
|
60 | 97 | (branch "dummy ID" |
61 | 98 | (rule "equiv_right" (formula "1") (newnames "f_o1,f_o2,f_lower2,f_upper2") (userinteraction)) |
62 | 99 | (branch "Case '->'" |
63 | 100 | (rule "notRight" (formula "2")) |
64 | 101 | (rule "andLeft" (formula "1")) |
65 | | - (rule "equalityToElementOf" (formula "3") (inst "ov=ov") (inst "fv=fv") (userinteraction)) |
| 102 | + (rule "equalityToElementOf" (formula "3") (inst "fv=fv") (inst "ov=ov") (userinteraction)) |
66 | 103 | (builtin "One Step Simplification" (formula "3")) |
67 | 104 | (rule "eqSymm" (formula "1")) |
68 | 105 | (rule "inEqSimp_commuteLeq" (formula "2")) |
|
108 | 145 | (rule "commute_or_2" (formula "3") (term "0,0,0,0")) |
109 | 146 | (rule "commute_or_2" (formula "3") (term "0,0,0")) |
110 | 147 | (builtin "One Step Simplification" (formula "3")) |
| 148 | + (rule "castDel" (formula "3") (term "0,0,0,0,0")) |
| 149 | + (builtin "One Step Simplification" (formula "3")) |
111 | 150 | (rule "polySimp_addComm1" (formula "3") (term "1")) |
112 | 151 | (rule "add_literals" (formula "3") (term "0,1")) |
113 | 152 | (rule "add_zero_left" (formula "3") (term "1")) |
|
131 | 170 | (rule "polySimp_pullOutFactor1b" (formula "3") (term "0")) |
132 | 171 | (rule "add_literals" (formula "3") (term "1,1,0")) |
133 | 172 | (rule "times_zero_1" (formula "3") (term "1,0")) |
134 | | - (rule "add_zero_right" (formula "3") (term "0")) |
| 173 | + (rule "add_literals" (formula "3") (term "0")) |
135 | 174 | (rule "leq_literals" (formula "3")) |
136 | 175 | (rule "closeFalse" (formula "3")) |
137 | 176 | ) |
138 | 177 | (branch "Case '<-'" |
139 | | - (rule "equalityToElementOfRight" (formula "2") (inst "ov=ov") (inst "fv=fv") (userinteraction)) |
| 178 | + (rule "equalityToElementOfRight" (formula "2") (inst "fv=fv") (inst "ov=ov") (userinteraction)) |
140 | 179 | (builtin "One Step Simplification" (formula "2")) |
141 | 180 | (rule "notLeft" (formula "1")) |
142 | | - (rule "allRight" (formula "2") (inst "sk=ov_0")) |
143 | | - (rule "allRight" (formula "2") (inst "sk=fv_0")) |
| 181 | + (rule "allRight" (formula "2") (inst "sk=ov_0:java.lang.Object")) |
| 182 | + (rule "allRight" (formula "2") (inst "sk=fv_0:Field")) |
144 | 183 | (rule "notRight" (formula "2")) |
145 | 184 | (rule "eqSymm" (formula "2") (term "0")) |
146 | 185 | (rule "inEqSimp_commuteLeq" (formula "2") (term "1")) |
|
150 | 189 | (rule "applyEq" (formula "2") (term "0") (ifseqformula "1")) |
151 | 190 | (rule "elementOfArrayRange" (formula "2") (inst "iv=iv")) |
152 | 191 | (rule "andLeft" (formula "2")) |
153 | | - (rule "exLeft" (formula "3") (inst "sk=iv_0")) |
| 192 | + (rule "exLeft" (formula "3") (inst "sk=iv_0:int")) |
154 | 193 | (rule "andLeft" (formula "3")) |
155 | 194 | (rule "andLeft" (formula "3")) |
156 | 195 | (rule "eqSymm" (formula "2")) |
|
0 commit comments