YES(?,POLY) * Step 1: TrivialSCCs WORST_CASE(?,POLY) + Considered Problem: Rules: 0. evalaaron2start(A,B,C) -> evalaaron2entryin(A,B,C) True (1,1) 1. evalaaron2entryin(A,B,C) -> evalaaron2bb6in(A,C,B) [A >= 0] (?,1) 2. evalaaron2entryin(A,B,C) -> evalaaron2returnin(A,B,C) [0 >= 1 + A] (?,1) 3. evalaaron2bb6in(A,B,C) -> evalaaron2returnin(A,B,C) [A >= 0 && B >= 1 + C] (?,1) 4. evalaaron2bb6in(A,B,C) -> evalaaron2bb3in(A,B,C) [A >= 0 && C >= B] (?,1) 5. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && 0 >= 1 + D] (?,1) 6. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && D >= 1] (?,1) 7. evalaaron2bb3in(A,B,C) -> evalaaron2bb5in(A,B,C) [-1*B + C >= 0 && A >= 0] (?,1) 8. evalaaron2bb4in(A,B,C) -> evalaaron2bb6in(A,B,-1 + -1*A + C) [-1*B + C >= 0 && A >= 0] (?,1) 9. evalaaron2bb5in(A,B,C) -> evalaaron2bb6in(A,1 + A + B,C) [-1*B + C >= 0 && A >= 0] (?,1) 10. evalaaron2returnin(A,B,C) -> evalaaron2stop(A,B,C) True (?,1) Signature: {(evalaaron2bb3in,3) ;(evalaaron2bb4in,3) ;(evalaaron2bb5in,3) ;(evalaaron2bb6in,3) ;(evalaaron2entryin,3) ;(evalaaron2returnin,3) ;(evalaaron2start,3) ;(evalaaron2stop,3)} Flow Graph: [0->{1,2},1->{3,4},2->{10},3->{10},4->{5,6,7},5->{8},6->{8},7->{9},8->{3,4},9->{3,4},10->{}] + Applied Processor: TrivialSCCs + Details: All trivial SCCs of the transition graph admit timebound 1. * Step 2: AddSinks WORST_CASE(?,POLY) + Considered Problem: Rules: 0. evalaaron2start(A,B,C) -> evalaaron2entryin(A,B,C) True (1,1) 1. evalaaron2entryin(A,B,C) -> evalaaron2bb6in(A,C,B) [A >= 0] (1,1) 2. evalaaron2entryin(A,B,C) -> evalaaron2returnin(A,B,C) [0 >= 1 + A] (1,1) 3. evalaaron2bb6in(A,B,C) -> evalaaron2returnin(A,B,C) [A >= 0 && B >= 1 + C] (1,1) 4. evalaaron2bb6in(A,B,C) -> evalaaron2bb3in(A,B,C) [A >= 0 && C >= B] (?,1) 5. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && 0 >= 1 + D] (?,1) 6. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && D >= 1] (?,1) 7. evalaaron2bb3in(A,B,C) -> evalaaron2bb5in(A,B,C) [-1*B + C >= 0 && A >= 0] (?,1) 8. evalaaron2bb4in(A,B,C) -> evalaaron2bb6in(A,B,-1 + -1*A + C) [-1*B + C >= 0 && A >= 0] (?,1) 9. evalaaron2bb5in(A,B,C) -> evalaaron2bb6in(A,1 + A + B,C) [-1*B + C >= 0 && A >= 0] (?,1) 10. evalaaron2returnin(A,B,C) -> evalaaron2stop(A,B,C) True (1,1) Signature: {(evalaaron2bb3in,3) ;(evalaaron2bb4in,3) ;(evalaaron2bb5in,3) ;(evalaaron2bb6in,3) ;(evalaaron2entryin,3) ;(evalaaron2returnin,3) ;(evalaaron2start,3) ;(evalaaron2stop,3)} Flow Graph: [0->{1,2},1->{3,4},2->{10},3->{10},4->{5,6,7},5->{8},6->{8},7->{9},8->{3,4},9->{3,4},10->{}] + Applied Processor: AddSinks + Details: () * Step 3: LooptreeTransformer WORST_CASE(?,POLY) + Considered Problem: Rules: 0. evalaaron2start(A,B,C) -> evalaaron2entryin(A,B,C) True (1,1) 1. evalaaron2entryin(A,B,C) -> evalaaron2bb6in(A,C,B) [A >= 0] (?,1) 2. evalaaron2entryin(A,B,C) -> evalaaron2returnin(A,B,C) [0 >= 1 + A] (?,1) 3. evalaaron2bb6in(A,B,C) -> evalaaron2returnin(A,B,C) [A >= 0 && B >= 1 + C] (?,1) 4. evalaaron2bb6in(A,B,C) -> evalaaron2bb3in(A,B,C) [A >= 0 && C >= B] (?,1) 5. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && 0 >= 1 + D] (?,1) 6. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && D >= 1] (?,1) 7. evalaaron2bb3in(A,B,C) -> evalaaron2bb5in(A,B,C) [-1*B + C >= 0 && A >= 0] (?,1) 8. evalaaron2bb4in(A,B,C) -> evalaaron2bb6in(A,B,-1 + -1*A + C) [-1*B + C >= 0 && A >= 0] (?,1) 9. evalaaron2bb5in(A,B,C) -> evalaaron2bb6in(A,1 + A + B,C) [-1*B + C >= 0 && A >= 0] (?,1) 10. evalaaron2returnin(A,B,C) -> evalaaron2stop(A,B,C) True (?,1) 11. evalaaron2returnin(A,B,C) -> exitus616(A,B,C) True (?,1) Signature: {(evalaaron2bb3in,3) ;(evalaaron2bb4in,3) ;(evalaaron2bb5in,3) ;(evalaaron2bb6in,3) ;(evalaaron2entryin,3) ;(evalaaron2returnin,3) ;(evalaaron2start,3) ;(evalaaron2stop,3) ;(exitus616,3)} Flow Graph: [0->{1,2},1->{3,4},2->{10,11},3->{10,11},4->{5,6,7},5->{8},6->{8},7->{9},8->{3,4},9->{3,4},10->{},11->{}] + Applied Processor: LooptreeTransformer + Details: We construct a looptree: P: [0,1,2,3,4,5,6,7,8,9,10,11] | `- p:[4,8,5,6,9,7] c: [9] | `- p:[4,8,5,6] c: [8] * Step 4: SizeAbstraction WORST_CASE(?,POLY) + Considered Problem: (Rules: 0. evalaaron2start(A,B,C) -> evalaaron2entryin(A,B,C) True (1,1) 1. evalaaron2entryin(A,B,C) -> evalaaron2bb6in(A,C,B) [A >= 0] (?,1) 2. evalaaron2entryin(A,B,C) -> evalaaron2returnin(A,B,C) [0 >= 1 + A] (?,1) 3. evalaaron2bb6in(A,B,C) -> evalaaron2returnin(A,B,C) [A >= 0 && B >= 1 + C] (?,1) 4. evalaaron2bb6in(A,B,C) -> evalaaron2bb3in(A,B,C) [A >= 0 && C >= B] (?,1) 5. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && 0 >= 1 + D] (?,1) 6. evalaaron2bb3in(A,B,C) -> evalaaron2bb4in(A,B,C) [-1*B + C >= 0 && A >= 0 && D >= 1] (?,1) 7. evalaaron2bb3in(A,B,C) -> evalaaron2bb5in(A,B,C) [-1*B + C >= 0 && A >= 0] (?,1) 8. evalaaron2bb4in(A,B,C) -> evalaaron2bb6in(A,B,-1 + -1*A + C) [-1*B + C >= 0 && A >= 0] (?,1) 9. evalaaron2bb5in(A,B,C) -> evalaaron2bb6in(A,1 + A + B,C) [-1*B + C >= 0 && A >= 0] (?,1) 10. evalaaron2returnin(A,B,C) -> evalaaron2stop(A,B,C) True (?,1) 11. evalaaron2returnin(A,B,C) -> exitus616(A,B,C) True (?,1) Signature: {(evalaaron2bb3in,3) ;(evalaaron2bb4in,3) ;(evalaaron2bb5in,3) ;(evalaaron2bb6in,3) ;(evalaaron2entryin,3) ;(evalaaron2returnin,3) ;(evalaaron2start,3) ;(evalaaron2stop,3) ;(exitus616,3)} Flow Graph: [0->{1,2},1->{3,4},2->{10,11},3->{10,11},4->{5,6,7},5->{8},6->{8},7->{9},8->{3,4},9->{3,4},10->{},11->{}] ,We construct a looptree: P: [0,1,2,3,4,5,6,7,8,9,10,11] | `- p:[4,8,5,6,9,7] c: [9] | `- p:[4,8,5,6] c: [8]) + Applied Processor: SizeAbstraction UseCFG Minimize + Details: () * Step 5: FlowAbstraction WORST_CASE(?,POLY) + Considered Problem: Program: Domain: [A,B,C,0.0,0.0.0] evalaaron2start ~> evalaaron2entryin [A <= A, B <= B, C <= C] evalaaron2entryin ~> evalaaron2bb6in [A <= A, B <= C, C <= B] evalaaron2entryin ~> evalaaron2returnin [A <= A, B <= B, C <= C] evalaaron2bb6in ~> evalaaron2returnin [A <= A, B <= B, C <= C] evalaaron2bb6in ~> evalaaron2bb3in [A <= A, B <= B, C <= C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] evalaaron2bb3in ~> evalaaron2bb5in [A <= A, B <= B, C <= C] evalaaron2bb4in ~> evalaaron2bb6in [A <= A, B <= B, C <= K + A + C] evalaaron2bb5in ~> evalaaron2bb6in [A <= A, B <= K + A + B, C <= C] evalaaron2returnin ~> evalaaron2stop [A <= A, B <= B, C <= C] evalaaron2returnin ~> exitus616 [A <= A, B <= B, C <= C] + Loop: [0.0 <= K + B + C] evalaaron2bb6in ~> evalaaron2bb3in [A <= A, B <= B, C <= C] evalaaron2bb4in ~> evalaaron2bb6in [A <= A, B <= B, C <= K + A + C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] evalaaron2bb5in ~> evalaaron2bb6in [A <= A, B <= K + A + B, C <= C] evalaaron2bb3in ~> evalaaron2bb5in [A <= A, B <= B, C <= C] + Loop: [0.0.0 <= K + B + C] evalaaron2bb6in ~> evalaaron2bb3in [A <= A, B <= B, C <= C] evalaaron2bb4in ~> evalaaron2bb6in [A <= A, B <= B, C <= K + A + C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] evalaaron2bb3in ~> evalaaron2bb4in [A <= A, B <= B, C <= C] + Applied Processor: FlowAbstraction + Details: () * Step 6: LareProcessor WORST_CASE(?,POLY) + Considered Problem: Program: Domain: [tick,huge,K,A,B,C,0.0,0.0.0] evalaaron2start ~> evalaaron2entryin [] evalaaron2entryin ~> evalaaron2bb6in [B ~=> C,C ~=> B] evalaaron2entryin ~> evalaaron2returnin [] evalaaron2bb6in ~> evalaaron2returnin [] evalaaron2bb6in ~> evalaaron2bb3in [] evalaaron2bb3in ~> evalaaron2bb4in [] evalaaron2bb3in ~> evalaaron2bb4in [] evalaaron2bb3in ~> evalaaron2bb5in [] evalaaron2bb4in ~> evalaaron2bb6in [A ~+> C,C ~+> C,K ~+> C] evalaaron2bb5in ~> evalaaron2bb6in [A ~+> B,B ~+> B,K ~+> B] evalaaron2returnin ~> evalaaron2stop [] evalaaron2returnin ~> exitus616 [] + Loop: [B ~+> 0.0,C ~+> 0.0,K ~+> 0.0] evalaaron2bb6in ~> evalaaron2bb3in [] evalaaron2bb4in ~> evalaaron2bb6in [A ~+> C,C ~+> C,K ~+> C] evalaaron2bb3in ~> evalaaron2bb4in [] evalaaron2bb3in ~> evalaaron2bb4in [] evalaaron2bb5in ~> evalaaron2bb6in [A ~+> B,B ~+> B,K ~+> B] evalaaron2bb3in ~> evalaaron2bb5in [] + Loop: [B ~+> 0.0.0,C ~+> 0.0.0,K ~+> 0.0.0] evalaaron2bb6in ~> evalaaron2bb3in [] evalaaron2bb4in ~> evalaaron2bb6in [A ~+> C,C ~+> C,K ~+> C] evalaaron2bb3in ~> evalaaron2bb4in [] evalaaron2bb3in ~> evalaaron2bb4in [] + Applied Processor: LareProcessor + Details: evalaaron2start ~> exitus616 [B ~=> C ,C ~=> B ,A ~+> B ,A ~+> C ,A ~+> 0.0.0 ,A ~+> tick ,B ~+> C ,B ~+> 0.0 ,B ~+> 0.0.0 ,B ~+> tick ,C ~+> B ,C ~+> 0.0 ,C ~+> 0.0.0 ,C ~+> tick ,tick ~+> tick ,K ~+> B ,K ~+> C ,K ~+> 0.0 ,K ~+> 0.0.0 ,K ~+> tick ,A ~*> B ,A ~*> C ,A ~*> 0.0.0 ,A ~*> tick ,B ~*> B ,B ~*> C ,B ~*> 0.0.0 ,B ~*> tick ,C ~*> B ,C ~*> C ,C ~*> 0.0.0 ,C ~*> tick ,K ~*> B ,K ~*> C ,K ~*> 0.0.0 ,K ~*> tick ,B ~^> C ,C ~^> C ,K ~^> C] evalaaron2start ~> evalaaron2stop [B ~=> C ,C ~=> B ,A ~+> B ,A ~+> C ,A ~+> 0.0.0 ,A ~+> tick ,B ~+> C ,B ~+> 0.0 ,B ~+> 0.0.0 ,B ~+> tick ,C ~+> B ,C ~+> 0.0 ,C ~+> 0.0.0 ,C ~+> tick ,tick ~+> tick ,K ~+> B ,K ~+> C ,K ~+> 0.0 ,K ~+> 0.0.0 ,K ~+> tick ,A ~*> B ,A ~*> C ,A ~*> 0.0.0 ,A ~*> tick ,B ~*> B ,B ~*> C ,B ~*> 0.0.0 ,B ~*> tick ,C ~*> B ,C ~*> C ,C ~*> 0.0.0 ,C ~*> tick ,K ~*> B ,K ~*> C ,K ~*> 0.0.0 ,K ~*> tick ,B ~^> C ,C ~^> C ,K ~^> C] + evalaaron2bb6in> [A ~+> B ,A ~+> C ,A ~+> 0.0.0 ,A ~+> tick ,B ~+> B ,B ~+> 0.0 ,B ~+> 0.0.0 ,B ~+> tick ,C ~+> C ,C ~+> 0.0 ,C ~+> 0.0.0 ,C ~+> tick ,tick ~+> tick ,K ~+> B ,K ~+> C ,K ~+> 0.0 ,K ~+> 0.0.0 ,K ~+> tick ,A ~*> B ,A ~*> C ,A ~*> 0.0.0 ,A ~*> tick ,B ~*> B ,B ~*> C ,B ~*> 0.0.0 ,B ~*> tick ,C ~*> B ,C ~*> C ,C ~*> 0.0.0 ,C ~*> tick ,K ~*> B ,K ~*> C ,K ~*> 0.0.0 ,K ~*> tick ,B ~^> C ,C ~^> C ,K ~^> C] + evalaaron2bb3in> [A ~+> C ,B ~+> 0.0.0 ,B ~+> tick ,C ~+> C ,C ~+> 0.0.0 ,C ~+> tick ,tick ~+> tick ,K ~+> C ,K ~+> 0.0.0 ,K ~+> tick ,A ~*> C ,B ~*> C ,C ~*> C ,K ~*> C] evalaaron2bb6in> [A ~+> C ,B ~+> 0.0.0 ,B ~+> tick ,C ~+> C ,C ~+> 0.0.0 ,C ~+> tick ,tick ~+> tick ,K ~+> C ,K ~+> 0.0.0 ,K ~+> tick ,A ~*> C ,B ~*> C ,C ~*> C ,K ~*> C] YES(?,POLY)