↳ PROLOG
↳ UnrequestedClauseRemoverProof
The clauses
notEq2(s1(X), s1(Y)) :- notEq2(X, Y).
notEq2(s1(X), 00).
notEq2(00, s1(X)).
lt2(s1(X), s1(Y)) :- lt2(X, Y).
lt2(00, s1(Y)).
gt2(s1(X), s1(Y)) :- gt2(X, Y).
gt2(s1(X), 00).
le2(s1(X), s1(Y)) :- le2(X, Y).
le2(00, s1(Y)).
le2(00, 00).
can be ignored, as they are not needed by any of the given querys.
Deleting these clauses results in the following prolog program:
myis2(Z, X) :- evaluate2(X, Z).
evaluate2(X + Y, Z) :- evaluate2(X, X1), evaluate2(Y, Y1), add3(X1, Y1, Z).
evaluate2(X - Y, Z) :- evaluate2(X, X1), evaluate2(Y, Y1), sub3(X1, Y1, Z).
evaluate2(X * Y, Z) :- evaluate2(X, X1), evaluate2(Y, Y1), mult3(X1, Y1, Z).
evaluate2(X, X) :- integer1(X).
integer1(s1(X)) :- integer1(X).
integer1(00).
add3(s1(X), Y, s1(Z)) :- add3(X, Y, Z).
add3(00, X, X).
sub3(s1(X), s1(Y), Z) :- sub3(X, Y, Z).
sub3(X, 00, X).
mult3(s1(X), Y, R) :- mult3(X, Y, Z), add3(Y, Z, R).
mult3(00, Y, 00).
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
With regard to the inferred argument filtering the predicates were used in the following modes:
myis2: (f,b)
evaluate2: (b,f)
integer1: (b)
mult3: (b,b,f)
add3: (b,b,f)
sub3: (b,b,f)
Transforming PROLOG into the following Term Rewriting System:
Pi-finite rewrite system:
The TRS R consists of the following rules:
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
Infinitary Constructor Rewriting Termination of PiTRS implies Termination of PROLOG
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
MYIS_2_IN_AG2(Z, X) -> IF_MYIS_2_IN_1_AG3(Z, X, evaluate_2_in_ga2(X, Z))
MYIS_2_IN_AG2(Z, X) -> EVALUATE_2_IN_GA2(X, Z)
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(X, X) -> IF_EVALUATE_2_IN_10_GA2(X, integer_1_in_g1(X))
EVALUATE_2_IN_GA2(X, X) -> INTEGER_1_IN_G1(X)
INTEGER_1_IN_G1(s_11(X)) -> IF_INTEGER_1_IN_1_G2(X, integer_1_in_g1(X))
INTEGER_1_IN_G1(s_11(X)) -> INTEGER_1_IN_G1(X)
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_9_GA6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> MULT_3_IN_GGA3(X1, Y1, Z)
MULT_3_IN_GGA3(s_11(X), Y, R) -> IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_in_gga3(X, Y, Z))
MULT_3_IN_GGA3(s_11(X), Y, R) -> MULT_3_IN_GGA3(X, Y, Z)
IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> IF_MULT_3_IN_2_GGA5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> ADD_3_IN_GGA3(Y, Z, R)
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> IF_ADD_3_IN_1_GGA4(X, Y, Z, add_3_in_gga3(X, Y, Z))
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> ADD_3_IN_GGA3(X, Y, Z)
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_6_GA6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> SUB_3_IN_GGA3(X1, Y1, Z)
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> IF_SUB_3_IN_1_GGA4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> SUB_3_IN_GGA3(X, Y, Z)
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_3_GA6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> ADD_3_IN_GGA3(X1, Y1, Z)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
MYIS_2_IN_AG2(Z, X) -> IF_MYIS_2_IN_1_AG3(Z, X, evaluate_2_in_ga2(X, Z))
MYIS_2_IN_AG2(Z, X) -> EVALUATE_2_IN_GA2(X, Z)
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(X, X) -> IF_EVALUATE_2_IN_10_GA2(X, integer_1_in_g1(X))
EVALUATE_2_IN_GA2(X, X) -> INTEGER_1_IN_G1(X)
INTEGER_1_IN_G1(s_11(X)) -> IF_INTEGER_1_IN_1_G2(X, integer_1_in_g1(X))
INTEGER_1_IN_G1(s_11(X)) -> INTEGER_1_IN_G1(X)
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_9_GA6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_8_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> MULT_3_IN_GGA3(X1, Y1, Z)
MULT_3_IN_GGA3(s_11(X), Y, R) -> IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_in_gga3(X, Y, Z))
MULT_3_IN_GGA3(s_11(X), Y, R) -> MULT_3_IN_GGA3(X, Y, Z)
IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> IF_MULT_3_IN_2_GGA5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
IF_MULT_3_IN_1_GGA4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> ADD_3_IN_GGA3(Y, Z, R)
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> IF_ADD_3_IN_1_GGA4(X, Y, Z, add_3_in_gga3(X, Y, Z))
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> ADD_3_IN_GGA3(X, Y, Z)
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_6_GA6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_5_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> SUB_3_IN_GGA3(X1, Y1, Z)
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> IF_SUB_3_IN_1_GGA4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> SUB_3_IN_GGA3(X, Y, Z)
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> IF_EVALUATE_2_IN_3_GA6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
IF_EVALUATE_2_IN_2_GA5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> ADD_3_IN_GGA3(X1, Y1, Z)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> SUB_3_IN_GGA3(X, Y, Z)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
SUB_3_IN_GGA3(s_11(X), s_11(Y), Z) -> SUB_3_IN_GGA3(X, Y, Z)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ QDP
↳ QDPSizeChangeProof
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
SUB_3_IN_GGA2(s_11(X), s_11(Y)) -> SUB_3_IN_GGA2(X, Y)
From the DPs we obtained the following set of size-change graphs:
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDP
↳ PiDP
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> ADD_3_IN_GGA3(X, Y, Z)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ PiDP
↳ PiDP
↳ PiDP
ADD_3_IN_GGA3(s_11(X), Y, s_11(Z)) -> ADD_3_IN_GGA3(X, Y, Z)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ QDP
↳ QDPSizeChangeProof
↳ PiDP
↳ PiDP
↳ PiDP
ADD_3_IN_GGA2(s_11(X), Y) -> ADD_3_IN_GGA2(X, Y)
From the DPs we obtained the following set of size-change graphs:
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDP
MULT_3_IN_GGA3(s_11(X), Y, R) -> MULT_3_IN_GGA3(X, Y, Z)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ PiDP
↳ PiDP
MULT_3_IN_GGA3(s_11(X), Y, R) -> MULT_3_IN_GGA3(X, Y, Z)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ QDP
↳ QDPSizeChangeProof
↳ PiDP
↳ PiDP
MULT_3_IN_GGA2(s_11(X), Y) -> MULT_3_IN_GGA2(X, Y)
From the DPs we obtained the following set of size-change graphs:
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
INTEGER_1_IN_G1(s_11(X)) -> INTEGER_1_IN_G1(X)
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ PiDP
INTEGER_1_IN_G1(s_11(X)) -> INTEGER_1_IN_G1(X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ QDP
↳ QDPSizeChangeProof
↳ PiDP
INTEGER_1_IN_G1(s_11(X)) -> INTEGER_1_IN_G1(X)
From the DPs we obtained the following set of size-change graphs:
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
myis_2_in_ag2(Z, X) -> if_myis_2_in_1_ag3(Z, X, evaluate_2_in_ga2(X, Z))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_myis_2_in_1_ag3(Z, X, evaluate_2_out_ga2(X, Z)) -> myis_2_out_ag2(Z, X)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> EVALUATE_2_IN_GA2(Y, Y1)
EVALUATE_2_IN_GA2(*2(X, Y), Z) -> IF_EVALUATE_2_IN_7_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(+2(X, Y), Z) -> IF_EVALUATE_2_IN_1_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> EVALUATE_2_IN_GA2(X, X1)
EVALUATE_2_IN_GA2(-2(X, Y), Z) -> IF_EVALUATE_2_IN_4_GA4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(+2(X, Y), Z) -> if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(-2(X, Y), Z) -> if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(*2(X, Y), Z) -> if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_in_ga2(X, X1))
evaluate_2_in_ga2(X, X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
if_evaluate_2_in_1_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_4_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_7_ga4(X, Y, Z, evaluate_2_out_ga2(X, X1)) -> if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_in_ga2(Y, Y1))
if_evaluate_2_in_10_ga2(X, integer_1_out_g1(X)) -> evaluate_2_out_ga2(X, X)
if_evaluate_2_in_2_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_5_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_in_gga3(X1, Y1, Z))
if_evaluate_2_in_8_ga5(X, Y, Z, X1, evaluate_2_out_ga2(Y, Y1)) -> if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_in_gga3(X1, Y1, Z))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g2(X, integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g1(0_0)
if_evaluate_2_in_3_ga6(X, Y, Z, X1, Y1, add_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(+2(X, Y), Z)
if_evaluate_2_in_6_ga6(X, Y, Z, X1, Y1, sub_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(-2(X, Y), Z)
if_evaluate_2_in_9_ga6(X, Y, Z, X1, Y1, mult_3_out_gga3(X1, Y1, Z)) -> evaluate_2_out_ga2(*2(X, Y), Z)
if_integer_1_in_1_g2(X, integer_1_out_g1(X)) -> integer_1_out_g1(s_11(X))
add_3_in_gga3(s_11(X), Y, s_11(Z)) -> if_add_3_in_1_gga4(X, Y, Z, add_3_in_gga3(X, Y, Z))
add_3_in_gga3(0_0, X, X) -> add_3_out_gga3(0_0, X, X)
sub_3_in_gga3(s_11(X), s_11(Y), Z) -> if_sub_3_in_1_gga4(X, Y, Z, sub_3_in_gga3(X, Y, Z))
sub_3_in_gga3(X, 0_0, X) -> sub_3_out_gga3(X, 0_0, X)
mult_3_in_gga3(s_11(X), Y, R) -> if_mult_3_in_1_gga4(X, Y, R, mult_3_in_gga3(X, Y, Z))
mult_3_in_gga3(0_0, Y, 0_0) -> mult_3_out_gga3(0_0, Y, 0_0)
if_add_3_in_1_gga4(X, Y, Z, add_3_out_gga3(X, Y, Z)) -> add_3_out_gga3(s_11(X), Y, s_11(Z))
if_sub_3_in_1_gga4(X, Y, Z, sub_3_out_gga3(X, Y, Z)) -> sub_3_out_gga3(s_11(X), s_11(Y), Z)
if_mult_3_in_1_gga4(X, Y, R, mult_3_out_gga3(X, Y, Z)) -> if_mult_3_in_2_gga5(X, Y, R, Z, add_3_in_gga3(Y, Z, R))
if_mult_3_in_2_gga5(X, Y, R, Z, add_3_out_gga3(Y, Z, R)) -> mult_3_out_gga3(s_11(X), Y, R)
↳ PROLOG
↳ UnrequestedClauseRemoverProof
↳ PROLOG
↳ PrologToPiTRSProof
↳ PiTRS
↳ DependencyPairsProof
↳ PiDP
↳ DependencyGraphProof
↳ AND
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ PiDP
↳ UsableRulesProof
↳ PiDP
↳ PiDPToQDPProof
↳ QDP
↳ QDPSizeChangeProof
EVALUATE_2_IN_GA1(+2(X, Y)) -> EVALUATE_2_IN_GA1(X)
IF_EVALUATE_2_IN_7_GA2(Y, evaluate_2_out_ga1(X1)) -> EVALUATE_2_IN_GA1(Y)
IF_EVALUATE_2_IN_4_GA2(Y, evaluate_2_out_ga1(X1)) -> EVALUATE_2_IN_GA1(Y)
EVALUATE_2_IN_GA1(*2(X, Y)) -> EVALUATE_2_IN_GA1(X)
IF_EVALUATE_2_IN_1_GA2(Y, evaluate_2_out_ga1(X1)) -> EVALUATE_2_IN_GA1(Y)
EVALUATE_2_IN_GA1(*2(X, Y)) -> IF_EVALUATE_2_IN_7_GA2(Y, evaluate_2_in_ga1(X))
EVALUATE_2_IN_GA1(+2(X, Y)) -> IF_EVALUATE_2_IN_1_GA2(Y, evaluate_2_in_ga1(X))
EVALUATE_2_IN_GA1(-2(X, Y)) -> EVALUATE_2_IN_GA1(X)
EVALUATE_2_IN_GA1(-2(X, Y)) -> IF_EVALUATE_2_IN_4_GA2(Y, evaluate_2_in_ga1(X))
evaluate_2_in_ga1(+2(X, Y)) -> if_evaluate_2_in_1_ga2(Y, evaluate_2_in_ga1(X))
evaluate_2_in_ga1(-2(X, Y)) -> if_evaluate_2_in_4_ga2(Y, evaluate_2_in_ga1(X))
evaluate_2_in_ga1(*2(X, Y)) -> if_evaluate_2_in_7_ga2(Y, evaluate_2_in_ga1(X))
evaluate_2_in_ga1(X) -> if_evaluate_2_in_10_ga2(X, integer_1_in_g1(X))
if_evaluate_2_in_1_ga2(Y, evaluate_2_out_ga1(X1)) -> if_evaluate_2_in_2_ga2(X1, evaluate_2_in_ga1(Y))
if_evaluate_2_in_4_ga2(Y, evaluate_2_out_ga1(X1)) -> if_evaluate_2_in_5_ga2(X1, evaluate_2_in_ga1(Y))
if_evaluate_2_in_7_ga2(Y, evaluate_2_out_ga1(X1)) -> if_evaluate_2_in_8_ga2(X1, evaluate_2_in_ga1(Y))
if_evaluate_2_in_10_ga2(X, integer_1_out_g) -> evaluate_2_out_ga1(X)
if_evaluate_2_in_2_ga2(X1, evaluate_2_out_ga1(Y1)) -> if_evaluate_2_in_3_ga1(add_3_in_gga2(X1, Y1))
if_evaluate_2_in_5_ga2(X1, evaluate_2_out_ga1(Y1)) -> if_evaluate_2_in_6_ga1(sub_3_in_gga2(X1, Y1))
if_evaluate_2_in_8_ga2(X1, evaluate_2_out_ga1(Y1)) -> if_evaluate_2_in_9_ga1(mult_3_in_gga2(X1, Y1))
integer_1_in_g1(s_11(X)) -> if_integer_1_in_1_g1(integer_1_in_g1(X))
integer_1_in_g1(0_0) -> integer_1_out_g
if_evaluate_2_in_3_ga1(add_3_out_gga1(Z)) -> evaluate_2_out_ga1(Z)
if_evaluate_2_in_6_ga1(sub_3_out_gga1(Z)) -> evaluate_2_out_ga1(Z)
if_evaluate_2_in_9_ga1(mult_3_out_gga1(Z)) -> evaluate_2_out_ga1(Z)
if_integer_1_in_1_g1(integer_1_out_g) -> integer_1_out_g
add_3_in_gga2(s_11(X), Y) -> if_add_3_in_1_gga1(add_3_in_gga2(X, Y))
add_3_in_gga2(0_0, X) -> add_3_out_gga1(X)
sub_3_in_gga2(s_11(X), s_11(Y)) -> if_sub_3_in_1_gga1(sub_3_in_gga2(X, Y))
sub_3_in_gga2(X, 0_0) -> sub_3_out_gga1(X)
mult_3_in_gga2(s_11(X), Y) -> if_mult_3_in_1_gga2(Y, mult_3_in_gga2(X, Y))
mult_3_in_gga2(0_0, Y) -> mult_3_out_gga1(0_0)
if_add_3_in_1_gga1(add_3_out_gga1(Z)) -> add_3_out_gga1(s_11(Z))
if_sub_3_in_1_gga1(sub_3_out_gga1(Z)) -> sub_3_out_gga1(Z)
if_mult_3_in_1_gga2(Y, mult_3_out_gga1(Z)) -> if_mult_3_in_2_gga1(add_3_in_gga2(Y, Z))
if_mult_3_in_2_gga1(add_3_out_gga1(R)) -> mult_3_out_gga1(R)
evaluate_2_in_ga1(x0)
if_evaluate_2_in_1_ga2(x0, x1)
if_evaluate_2_in_4_ga2(x0, x1)
if_evaluate_2_in_7_ga2(x0, x1)
if_evaluate_2_in_10_ga2(x0, x1)
if_evaluate_2_in_2_ga2(x0, x1)
if_evaluate_2_in_5_ga2(x0, x1)
if_evaluate_2_in_8_ga2(x0, x1)
integer_1_in_g1(x0)
if_evaluate_2_in_3_ga1(x0)
if_evaluate_2_in_6_ga1(x0)
if_evaluate_2_in_9_ga1(x0)
if_integer_1_in_1_g1(x0)
add_3_in_gga2(x0, x1)
sub_3_in_gga2(x0, x1)
mult_3_in_gga2(x0, x1)
if_add_3_in_1_gga1(x0)
if_sub_3_in_1_gga1(x0)
if_mult_3_in_1_gga2(x0, x1)
if_mult_3_in_2_gga1(x0)
From the DPs we obtained the following set of size-change graphs: