Start: start
Program_Vars: X₀, X₁
Temp_Vars: C
Locations: eval, start
Transitions:
t₀: eval(X₀, X₁) → eval(X₀-1, C) :|: 1 ≤ X₀ ∧ 1 ≤ X₁
t₁: eval(X₀, X₁) → eval(X₀, X₁-1) :|: 1 ≤ X₀ ∧ 1 ≤ X₁
t₂: start(X₀, X₁) → eval(X₀, X₁)
Start: start
Program_Vars: X₀, X₁
Temp_Vars: C
Locations: eval, start
Transitions:
t₀: eval(X₀, X₁) → eval(X₀-1, C) :|: 1 ≤ X₀ ∧ 1 ≤ X₁
t₁: eval(X₀, X₁) → eval(X₀, X₁-1) :|: 1 ≤ X₀ ∧ 1 ≤ X₁
t₂: start(X₀, X₁) → eval(X₀, X₁)
new bound:
X₀ {O(n)}
MPRF:
• eval: [X₀]
Found invariant 0 ≤ X₁ ∧ 1 ≤ X₀+X₁ ∧ 1 ≤ X₀ for location eval_v1
Found invariant 0 ≤ X₀ for location eval_v2
Overall timebound:inf {Infinity}
t₀: X₀ {O(n)}
t₁: inf {Infinity}
t₂: 1 {O(1)}
Overall costbound: inf {Infinity}
t₀: X₀ {O(n)}
t₁: inf {Infinity}
t₂: 1 {O(1)}
t₀, X₀: X₀ {O(n)}
t₁, X₀: X₀ {O(n)}
t₂, X₀: X₀ {O(n)}
t₂, X₁: X₁ {O(n)}