Start: evalEx3start
Program_Vars: Arg_0, Arg_1, Arg_2
Temp_Vars: D
Locations: evalEx3bb1in, evalEx3bb2in, evalEx3bb3in, evalEx3bb4in, evalEx3bbin, evalEx3entryin, evalEx3returnin, evalEx3start, evalEx3stop
Transitions:
10:evalEx3bb1in(Arg_0,Arg_1,Arg_2) -> evalEx3bb2in(Arg_0,Arg_1,Arg_2-1)
6:evalEx3bb2in(Arg_0,Arg_1,Arg_2) -> evalEx3bb3in(Arg_0,Arg_1,Arg_2):|:1<=Arg_2
5:evalEx3bb2in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:Arg_2<=0
7:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb1in(Arg_0,Arg_1,Arg_2)
8:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:D+1<=Arg_1
9:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:Arg_1+1<=D
2:evalEx3bb4in(Arg_0,Arg_1,Arg_2) -> evalEx3bbin(Arg_0,Arg_1,Arg_2):|:1<=Arg_0
3:evalEx3bb4in(Arg_0,Arg_1,Arg_2) -> evalEx3returnin(Arg_0,Arg_1,Arg_2):|:Arg_0<=0
4:evalEx3bbin(Arg_0,Arg_1,Arg_2) -> evalEx3bb2in(Arg_0,D,Arg_0)
1:evalEx3entryin(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_0,Arg_1,Arg_2)
11:evalEx3returnin(Arg_0,Arg_1,Arg_2) -> evalEx3stop(Arg_0,Arg_1,Arg_2)
0:evalEx3start(Arg_0,Arg_1,Arg_2) -> evalEx3entryin(Arg_0,Arg_1,Arg_2)
Found invariant Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0 for location evalEx3bb1in
Found invariant Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0 for location evalEx3bb3in
Found invariant Arg_0<=0 for location evalEx3returnin
Found invariant Arg_0<=0 for location evalEx3stop
Found invariant Arg_2<=Arg_0 && 0<=Arg_2 && 1<=Arg_0+Arg_2 && 1<=Arg_0 for location evalEx3bb2in
Found invariant 1<=Arg_0 for location evalEx3bbin
Start: evalEx3start
Program_Vars: Arg_0, Arg_1, Arg_2
Temp_Vars: D
Locations: evalEx3bb1in, evalEx3bb2in, evalEx3bb3in, evalEx3bb4in, evalEx3bbin, evalEx3entryin, evalEx3returnin, evalEx3start, evalEx3stop
Transitions:
10:evalEx3bb1in(Arg_0,Arg_1,Arg_2) -> evalEx3bb2in(Arg_0,Arg_1,Arg_2-1):|:Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0
6:evalEx3bb2in(Arg_0,Arg_1,Arg_2) -> evalEx3bb3in(Arg_0,Arg_1,Arg_2):|:Arg_2<=Arg_0 && 0<=Arg_2 && 1<=Arg_0+Arg_2 && 1<=Arg_0 && 1<=Arg_2
5:evalEx3bb2in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:Arg_2<=Arg_0 && 0<=Arg_2 && 1<=Arg_0+Arg_2 && 1<=Arg_0 && Arg_2<=0
7:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb1in(Arg_0,Arg_1,Arg_2):|:Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0
8:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0 && D+1<=Arg_1
9:evalEx3bb3in(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_2,Arg_1,Arg_2):|:Arg_2<=Arg_0 && 1<=Arg_2 && 2<=Arg_0+Arg_2 && 1<=Arg_0 && Arg_1+1<=D
2:evalEx3bb4in(Arg_0,Arg_1,Arg_2) -> evalEx3bbin(Arg_0,Arg_1,Arg_2):|:1<=Arg_0
3:evalEx3bb4in(Arg_0,Arg_1,Arg_2) -> evalEx3returnin(Arg_0,Arg_1,Arg_2):|:Arg_0<=0
4:evalEx3bbin(Arg_0,Arg_1,Arg_2) -> evalEx3bb2in(Arg_0,D,Arg_0):|:1<=Arg_0
1:evalEx3entryin(Arg_0,Arg_1,Arg_2) -> evalEx3bb4in(Arg_0,Arg_1,Arg_2)
11:evalEx3returnin(Arg_0,Arg_1,Arg_2) -> evalEx3stop(Arg_0,Arg_1,Arg_2):|:Arg_0<=0
0:evalEx3start(Arg_0,Arg_1,Arg_2) -> evalEx3entryin(Arg_0,Arg_1,Arg_2)
new bound:
Arg_0 {O(n)}
MPRF:
evalEx3bb1in [Arg_2 ]
evalEx3bb3in [Arg_2 ]
evalEx3bb4in [Arg_0 ]
evalEx3bbin [Arg_0 ]
evalEx3bb2in [Arg_2 ]
new bound:
Arg_0+1 {O(n)}
MPRF:
evalEx3bb1in [Arg_0+1 ]
evalEx3bb3in [Arg_0+1 ]
evalEx3bb4in [Arg_0+1 ]
evalEx3bbin [Arg_0+1 ]
evalEx3bb2in [Arg_0+1 ]
new bound:
Arg_0 {O(n)}
MPRF:
evalEx3bb1in [Arg_2-1 ]
evalEx3bb3in [Arg_2 ]
evalEx3bb4in [Arg_0 ]
evalEx3bbin [Arg_0 ]
evalEx3bb2in [Arg_2 ]
Overall timebound:inf {Infinity}
10: evalEx3bb1in->evalEx3bb2in: Arg_0 {O(n)}
5: evalEx3bb2in->evalEx3bb4in: Arg_0+1 {O(n)}
6: evalEx3bb2in->evalEx3bb3in: inf {Infinity}
7: evalEx3bb3in->evalEx3bb1in: Arg_0 {O(n)}
8: evalEx3bb3in->evalEx3bb4in: inf {Infinity}
9: evalEx3bb3in->evalEx3bb4in: inf {Infinity}
2: evalEx3bb4in->evalEx3bbin: inf {Infinity}
3: evalEx3bb4in->evalEx3returnin: 1 {O(1)}
4: evalEx3bbin->evalEx3bb2in: inf {Infinity}
1: evalEx3entryin->evalEx3bb4in: 1 {O(1)}
11: evalEx3returnin->evalEx3stop: 1 {O(1)}
0: evalEx3start->evalEx3entryin: 1 {O(1)}
Overall costbound: inf {Infinity}
10: evalEx3bb1in->evalEx3bb2in: Arg_0 {O(n)}
5: evalEx3bb2in->evalEx3bb4in: Arg_0+1 {O(n)}
6: evalEx3bb2in->evalEx3bb3in: inf {Infinity}
7: evalEx3bb3in->evalEx3bb1in: Arg_0 {O(n)}
8: evalEx3bb3in->evalEx3bb4in: inf {Infinity}
9: evalEx3bb3in->evalEx3bb4in: inf {Infinity}
2: evalEx3bb4in->evalEx3bbin: inf {Infinity}
3: evalEx3bb4in->evalEx3returnin: 1 {O(1)}
4: evalEx3bbin->evalEx3bb2in: inf {Infinity}
1: evalEx3entryin->evalEx3bb4in: 1 {O(1)}
11: evalEx3returnin->evalEx3stop: 1 {O(1)}
0: evalEx3start->evalEx3entryin: 1 {O(1)}
10: evalEx3bb1in->evalEx3bb2in, Arg_0: Arg_0 {O(n)}
10: evalEx3bb1in->evalEx3bb2in, Arg_2: Arg_0 {O(n)}
5: evalEx3bb2in->evalEx3bb4in, Arg_0: 0 {O(1)}
5: evalEx3bb2in->evalEx3bb4in, Arg_2: 0 {O(1)}
6: evalEx3bb2in->evalEx3bb3in, Arg_0: Arg_0 {O(n)}
6: evalEx3bb2in->evalEx3bb3in, Arg_2: Arg_0 {O(n)}
7: evalEx3bb3in->evalEx3bb1in, Arg_0: Arg_0 {O(n)}
7: evalEx3bb3in->evalEx3bb1in, Arg_2: Arg_0 {O(n)}
8: evalEx3bb3in->evalEx3bb4in, Arg_0: Arg_0 {O(n)}
8: evalEx3bb3in->evalEx3bb4in, Arg_2: Arg_0 {O(n)}
9: evalEx3bb3in->evalEx3bb4in, Arg_0: Arg_0 {O(n)}
9: evalEx3bb3in->evalEx3bb4in, Arg_2: Arg_0 {O(n)}
2: evalEx3bb4in->evalEx3bbin, Arg_0: Arg_0 {O(n)}
2: evalEx3bb4in->evalEx3bbin, Arg_2: 2*Arg_0+Arg_2 {O(n)}
3: evalEx3bb4in->evalEx3returnin, Arg_0: Arg_0 {O(n)}
3: evalEx3bb4in->evalEx3returnin, Arg_2: Arg_2 {O(n)}
4: evalEx3bbin->evalEx3bb2in, Arg_0: Arg_0 {O(n)}
4: evalEx3bbin->evalEx3bb2in, Arg_2: Arg_0 {O(n)}
1: evalEx3entryin->evalEx3bb4in, Arg_0: Arg_0 {O(n)}
1: evalEx3entryin->evalEx3bb4in, Arg_1: Arg_1 {O(n)}
1: evalEx3entryin->evalEx3bb4in, Arg_2: Arg_2 {O(n)}
11: evalEx3returnin->evalEx3stop, Arg_0: Arg_0 {O(n)}
11: evalEx3returnin->evalEx3stop, Arg_2: Arg_2 {O(n)}
0: evalEx3start->evalEx3entryin, Arg_0: Arg_0 {O(n)}
0: evalEx3start->evalEx3entryin, Arg_1: Arg_1 {O(n)}
0: evalEx3start->evalEx3entryin, Arg_2: Arg_2 {O(n)}