(0) Obligation:

Clauses:

shapes(Matrix, N) :- ','(varmat(Matrix, MatrixWithVars), unif_matrx(MatrixWithVars)).
varmat([], []).
varmat(.(L, Ls), .(VL, VLs)) :- ','(varmat(L, VL), varmat(Ls, VLs)).
varmat(.(black, Xs), .(black, VXs)) :- varmat(Xs, VXs).
varmat(.(white, Xs), .(w(X1), VXs)) :- varmat(Xs, VXs).
unif_matrx(.(L1, .(L2, Ls))) :- ','(unif_lines(L1, L2), unif_matrx(.(L2, Ls))).
unif_matrx(.(X2, [])).
unif_lines(.(W, .(X, L1s)), .(Y, .(Z, L2s))) :- ','(unif_pairs(.(W, .(X, .(Y, .(Z, .(W, .(Y, .(X, .(Z, .(W, .(Z, .(X, .(Y, []))))))))))))), unif_lines(.(X, L1s), .(Z, L2s))).
unif_lines(.(X3, []), .(X4, [])).
unif_pairs([]).
unif_pairs(.(A, .(B, Pairs))) :- ','(unif(A, B), unif_pairs(Pairs)).
unif(w(A), w(A)).
unif(black, black).
unif(black, w(X5)).
unif(w(X6), black).

Query: shapes(g,a)

(1) PrologToPiTRSViaGraphTransformerProof (SOUND transformation)

Transformed Prolog program to (Pi-)TRS.

(2) Obligation:

Pi-finite rewrite system:
The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)

(3) DependencyPairsProof (EQUIVALENT transformation)

Using Dependency Pairs [AG00,LOPSTR] we result in the following initial DP problem:
Pi DP problem:
The TRS P consists of the following rules:

SHAPESA_IN_GA(.(T15, T16), T6) → U1_GA(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
SHAPESA_IN_GA(.(T15, T16), T6) → PB_IN_GAGA(T15, X47, T16, X48)
PB_IN_GAGA(T15, T17, T16, X48) → U17_GAGA(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
PB_IN_GAGA(T15, T17, T16, X48) → VARMATE_IN_GA(T15, T17)
VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → U4_GA(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → PF_IN_GAGA(T26, X77, T27, X78)
PF_IN_GAGA(T26, T28, T27, X78) → U21_GAGA(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
PF_IN_GAGA(T26, T28, T27, X78) → VARMATE_IN_GA(T26, T28)
VARMATE_IN_GA(.(black, T33), .(black, X93)) → U5_GA(T33, X93, varmatE_in_ga(T33, X93))
VARMATE_IN_GA(.(black, T33), .(black, X93)) → VARMATE_IN_GA(T33, X93)
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → U6_GA(T36, X107, X108, varmatE_in_ga(T36, X108))
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → VARMATE_IN_GA(T36, X108)
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_GAGA(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27, X78)
U17_GAGA(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_GAGA(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
U17_GAGA(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → PD_IN_GAG(T16, X48, T17)
PD_IN_GAG(T16, T37, T17) → U19_GAG(T16, T37, T17, varmatE_in_ga(T16, T37))
PD_IN_GAG(T16, T37, T17) → VARMATE_IN_GA(T16, T37)
U19_GAG(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_GAG(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
U19_GAG(T16, T37, T17, varmatE_out_ga(T16, T37)) → UNIF_MATRXG_IN_GG(T17, T37)
UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → U7_GG(T56, T57, T58, pH_in_ggg(T56, T57, T58))
UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
PH_IN_GGG(T56, T65, T66) → UNIF_LINESI_IN_GG(T56, T65)
UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_GG(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → UNIF_PAIRSL_IN_GG(T103, T109)
UNIF_PAIRSL_IN_GG(w(T130), .(w(T130), T131)) → U13_GG(T130, T131, unif_pairsK_in_g(T131))
UNIF_PAIRSL_IN_GG(w(T130), .(w(T130), T131)) → UNIF_PAIRSK_IN_G(T131)
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → U9_G(T148, T149, unif_pairsK_in_g(T149))
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → UNIF_PAIRSK_IN_G(T149)
UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → U10_G(T150, unif_pairsK_in_g(T150))
UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → U11_G(T155, T156, unif_pairsK_in_g(T156))
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → UNIF_PAIRSK_IN_G(T156)
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → U12_G(T159, T160, unif_pairsK_in_g(T160))
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → UNIF_PAIRSK_IN_G(T160)
UNIF_PAIRSL_IN_GG(black, .(black, T161)) → U14_GG(T161, unif_pairsK_in_g(T161))
UNIF_PAIRSL_IN_GG(black, .(black, T161)) → UNIF_PAIRSK_IN_G(T161)
UNIF_PAIRSL_IN_GG(black, .(w(T166), T167)) → U15_GG(T166, T167, unif_pairsK_in_g(T167))
UNIF_PAIRSL_IN_GG(black, .(w(T166), T167)) → UNIF_PAIRSK_IN_G(T167)
UNIF_PAIRSL_IN_GG(w(T170), .(black, T171)) → U16_GG(T170, T171, unif_pairsK_in_g(T171))
UNIF_PAIRSL_IN_GG(w(T170), .(black, T171)) → UNIF_PAIRSK_IN_G(T171)
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_GGGGGG(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_GGG(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)
SHAPESA_IN_GA(.(black, T194), T6) → U2_GA(T194, T6, pC_in_ga(T194, X245))
SHAPESA_IN_GA(.(black, T194), T6) → PC_IN_GA(T194, X245)
PC_IN_GA(T194, T195) → U27_GA(T194, T195, varmatE_in_ga(T194, T195))
PC_IN_GA(T194, T195) → VARMATE_IN_GA(T194, T195)
U27_GA(T194, T195, varmatE_out_ga(T194, T195)) → U28_GA(T194, T195, unif_matrxM_in_g(T195))
U27_GA(T194, T195, varmatE_out_ga(T194, T195)) → UNIF_MATRXM_IN_G(T195)
SHAPESA_IN_GA(.(white, T217), T6) → U3_GA(T217, T6, pD_in_gag(T217, X304, w(X303)))
SHAPESA_IN_GA(.(white, T217), T6) → PD_IN_GAG(T217, X304, w(X303))

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
SHAPESA_IN_GA(x1, x2)  =  SHAPESA_IN_GA(x1)
U1_GA(x1, x2, x3, x4)  =  U1_GA(x1, x2, x4)
PB_IN_GAGA(x1, x2, x3, x4)  =  PB_IN_GAGA(x1, x3)
U17_GAGA(x1, x2, x3, x4, x5)  =  U17_GAGA(x1, x3, x5)
VARMATE_IN_GA(x1, x2)  =  VARMATE_IN_GA(x1)
U4_GA(x1, x2, x3, x4, x5)  =  U4_GA(x1, x2, x5)
PF_IN_GAGA(x1, x2, x3, x4)  =  PF_IN_GAGA(x1, x3)
U21_GAGA(x1, x2, x3, x4, x5)  =  U21_GAGA(x1, x3, x5)
U5_GA(x1, x2, x3)  =  U5_GA(x1, x3)
U6_GA(x1, x2, x3, x4)  =  U6_GA(x1, x4)
U22_GAGA(x1, x2, x3, x4, x5)  =  U22_GAGA(x1, x2, x3, x5)
U18_GAGA(x1, x2, x3, x4, x5)  =  U18_GAGA(x1, x2, x3, x5)
PD_IN_GAG(x1, x2, x3)  =  PD_IN_GAG(x1, x3)
U19_GAG(x1, x2, x3, x4)  =  U19_GAG(x1, x3, x4)
U20_GAG(x1, x2, x3, x4)  =  U20_GAG(x1, x2, x3, x4)
UNIF_MATRXG_IN_GG(x1, x2)  =  UNIF_MATRXG_IN_GG(x1, x2)
U7_GG(x1, x2, x3, x4)  =  U7_GG(x1, x2, x3, x4)
PH_IN_GGG(x1, x2, x3)  =  PH_IN_GGG(x1, x2, x3)
U23_GGG(x1, x2, x3, x4)  =  U23_GGG(x1, x2, x3, x4)
UNIF_LINESI_IN_GG(x1, x2)  =  UNIF_LINESI_IN_GG(x1, x2)
U8_GG(x1, x2, x3, x4, x5, x6, x7)  =  U8_GG(x1, x2, x3, x4, x5, x6, x7)
PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)  =  PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)
U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)
UNIF_PAIRSL_IN_GG(x1, x2)  =  UNIF_PAIRSL_IN_GG(x1, x2)
U13_GG(x1, x2, x3)  =  U13_GG(x2, x3)
UNIF_PAIRSK_IN_G(x1)  =  UNIF_PAIRSK_IN_G(x1)
U9_G(x1, x2, x3)  =  U9_G(x2, x3)
U10_G(x1, x2)  =  U10_G(x1, x2)
U11_G(x1, x2, x3)  =  U11_G(x2, x3)
U12_G(x1, x2, x3)  =  U12_G(x2, x3)
U14_GG(x1, x2)  =  U14_GG(x1, x2)
U15_GG(x1, x2, x3)  =  U15_GG(x2, x3)
U16_GG(x1, x2, x3)  =  U16_GG(x2, x3)
U26_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U26_GGGGGG(x1, x2, x3, x4, x5, x6, x7)
U24_GGG(x1, x2, x3, x4)  =  U24_GGG(x1, x2, x3, x4)
U2_GA(x1, x2, x3)  =  U2_GA(x1, x3)
PC_IN_GA(x1, x2)  =  PC_IN_GA(x1)
U27_GA(x1, x2, x3)  =  U27_GA(x1, x3)
U28_GA(x1, x2, x3)  =  U28_GA(x1, x2, x3)
UNIF_MATRXM_IN_G(x1)  =  UNIF_MATRXM_IN_G(x1)
U3_GA(x1, x2, x3)  =  U3_GA(x1, x3)

We have to consider all (P,R,Pi)-chains

(4) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

SHAPESA_IN_GA(.(T15, T16), T6) → U1_GA(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
SHAPESA_IN_GA(.(T15, T16), T6) → PB_IN_GAGA(T15, X47, T16, X48)
PB_IN_GAGA(T15, T17, T16, X48) → U17_GAGA(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
PB_IN_GAGA(T15, T17, T16, X48) → VARMATE_IN_GA(T15, T17)
VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → U4_GA(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → PF_IN_GAGA(T26, X77, T27, X78)
PF_IN_GAGA(T26, T28, T27, X78) → U21_GAGA(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
PF_IN_GAGA(T26, T28, T27, X78) → VARMATE_IN_GA(T26, T28)
VARMATE_IN_GA(.(black, T33), .(black, X93)) → U5_GA(T33, X93, varmatE_in_ga(T33, X93))
VARMATE_IN_GA(.(black, T33), .(black, X93)) → VARMATE_IN_GA(T33, X93)
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → U6_GA(T36, X107, X108, varmatE_in_ga(T36, X108))
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → VARMATE_IN_GA(T36, X108)
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_GAGA(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27, X78)
U17_GAGA(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_GAGA(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
U17_GAGA(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → PD_IN_GAG(T16, X48, T17)
PD_IN_GAG(T16, T37, T17) → U19_GAG(T16, T37, T17, varmatE_in_ga(T16, T37))
PD_IN_GAG(T16, T37, T17) → VARMATE_IN_GA(T16, T37)
U19_GAG(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_GAG(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
U19_GAG(T16, T37, T17, varmatE_out_ga(T16, T37)) → UNIF_MATRXG_IN_GG(T17, T37)
UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → U7_GG(T56, T57, T58, pH_in_ggg(T56, T57, T58))
UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
PH_IN_GGG(T56, T65, T66) → UNIF_LINESI_IN_GG(T56, T65)
UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_GG(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → UNIF_PAIRSL_IN_GG(T103, T109)
UNIF_PAIRSL_IN_GG(w(T130), .(w(T130), T131)) → U13_GG(T130, T131, unif_pairsK_in_g(T131))
UNIF_PAIRSL_IN_GG(w(T130), .(w(T130), T131)) → UNIF_PAIRSK_IN_G(T131)
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → U9_G(T148, T149, unif_pairsK_in_g(T149))
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → UNIF_PAIRSK_IN_G(T149)
UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → U10_G(T150, unif_pairsK_in_g(T150))
UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → U11_G(T155, T156, unif_pairsK_in_g(T156))
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → UNIF_PAIRSK_IN_G(T156)
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → U12_G(T159, T160, unif_pairsK_in_g(T160))
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → UNIF_PAIRSK_IN_G(T160)
UNIF_PAIRSL_IN_GG(black, .(black, T161)) → U14_GG(T161, unif_pairsK_in_g(T161))
UNIF_PAIRSL_IN_GG(black, .(black, T161)) → UNIF_PAIRSK_IN_G(T161)
UNIF_PAIRSL_IN_GG(black, .(w(T166), T167)) → U15_GG(T166, T167, unif_pairsK_in_g(T167))
UNIF_PAIRSL_IN_GG(black, .(w(T166), T167)) → UNIF_PAIRSK_IN_G(T167)
UNIF_PAIRSL_IN_GG(w(T170), .(black, T171)) → U16_GG(T170, T171, unif_pairsK_in_g(T171))
UNIF_PAIRSL_IN_GG(w(T170), .(black, T171)) → UNIF_PAIRSK_IN_G(T171)
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_GGGGGG(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_GGG(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)
SHAPESA_IN_GA(.(black, T194), T6) → U2_GA(T194, T6, pC_in_ga(T194, X245))
SHAPESA_IN_GA(.(black, T194), T6) → PC_IN_GA(T194, X245)
PC_IN_GA(T194, T195) → U27_GA(T194, T195, varmatE_in_ga(T194, T195))
PC_IN_GA(T194, T195) → VARMATE_IN_GA(T194, T195)
U27_GA(T194, T195, varmatE_out_ga(T194, T195)) → U28_GA(T194, T195, unif_matrxM_in_g(T195))
U27_GA(T194, T195, varmatE_out_ga(T194, T195)) → UNIF_MATRXM_IN_G(T195)
SHAPESA_IN_GA(.(white, T217), T6) → U3_GA(T217, T6, pD_in_gag(T217, X304, w(X303)))
SHAPESA_IN_GA(.(white, T217), T6) → PD_IN_GAG(T217, X304, w(X303))

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
SHAPESA_IN_GA(x1, x2)  =  SHAPESA_IN_GA(x1)
U1_GA(x1, x2, x3, x4)  =  U1_GA(x1, x2, x4)
PB_IN_GAGA(x1, x2, x3, x4)  =  PB_IN_GAGA(x1, x3)
U17_GAGA(x1, x2, x3, x4, x5)  =  U17_GAGA(x1, x3, x5)
VARMATE_IN_GA(x1, x2)  =  VARMATE_IN_GA(x1)
U4_GA(x1, x2, x3, x4, x5)  =  U4_GA(x1, x2, x5)
PF_IN_GAGA(x1, x2, x3, x4)  =  PF_IN_GAGA(x1, x3)
U21_GAGA(x1, x2, x3, x4, x5)  =  U21_GAGA(x1, x3, x5)
U5_GA(x1, x2, x3)  =  U5_GA(x1, x3)
U6_GA(x1, x2, x3, x4)  =  U6_GA(x1, x4)
U22_GAGA(x1, x2, x3, x4, x5)  =  U22_GAGA(x1, x2, x3, x5)
U18_GAGA(x1, x2, x3, x4, x5)  =  U18_GAGA(x1, x2, x3, x5)
PD_IN_GAG(x1, x2, x3)  =  PD_IN_GAG(x1, x3)
U19_GAG(x1, x2, x3, x4)  =  U19_GAG(x1, x3, x4)
U20_GAG(x1, x2, x3, x4)  =  U20_GAG(x1, x2, x3, x4)
UNIF_MATRXG_IN_GG(x1, x2)  =  UNIF_MATRXG_IN_GG(x1, x2)
U7_GG(x1, x2, x3, x4)  =  U7_GG(x1, x2, x3, x4)
PH_IN_GGG(x1, x2, x3)  =  PH_IN_GGG(x1, x2, x3)
U23_GGG(x1, x2, x3, x4)  =  U23_GGG(x1, x2, x3, x4)
UNIF_LINESI_IN_GG(x1, x2)  =  UNIF_LINESI_IN_GG(x1, x2)
U8_GG(x1, x2, x3, x4, x5, x6, x7)  =  U8_GG(x1, x2, x3, x4, x5, x6, x7)
PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)  =  PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)
U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)
UNIF_PAIRSL_IN_GG(x1, x2)  =  UNIF_PAIRSL_IN_GG(x1, x2)
U13_GG(x1, x2, x3)  =  U13_GG(x2, x3)
UNIF_PAIRSK_IN_G(x1)  =  UNIF_PAIRSK_IN_G(x1)
U9_G(x1, x2, x3)  =  U9_G(x2, x3)
U10_G(x1, x2)  =  U10_G(x1, x2)
U11_G(x1, x2, x3)  =  U11_G(x2, x3)
U12_G(x1, x2, x3)  =  U12_G(x2, x3)
U14_GG(x1, x2)  =  U14_GG(x1, x2)
U15_GG(x1, x2, x3)  =  U15_GG(x2, x3)
U16_GG(x1, x2, x3)  =  U16_GG(x2, x3)
U26_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U26_GGGGGG(x1, x2, x3, x4, x5, x6, x7)
U24_GGG(x1, x2, x3, x4)  =  U24_GGG(x1, x2, x3, x4)
U2_GA(x1, x2, x3)  =  U2_GA(x1, x3)
PC_IN_GA(x1, x2)  =  PC_IN_GA(x1)
U27_GA(x1, x2, x3)  =  U27_GA(x1, x3)
U28_GA(x1, x2, x3)  =  U28_GA(x1, x2, x3)
UNIF_MATRXM_IN_G(x1)  =  UNIF_MATRXM_IN_G(x1)
U3_GA(x1, x2, x3)  =  U3_GA(x1, x3)

We have to consider all (P,R,Pi)-chains

(5) DependencyGraphProof (EQUIVALENT transformation)

The approximation of the Dependency Graph [LOPSTR] contains 4 SCCs with 40 less nodes.

(6) Complex Obligation (AND)

(7) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → UNIF_PAIRSK_IN_G(T149)
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → UNIF_PAIRSK_IN_G(T156)
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → UNIF_PAIRSK_IN_G(T160)

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
UNIF_PAIRSK_IN_G(x1)  =  UNIF_PAIRSK_IN_G(x1)

We have to consider all (P,R,Pi)-chains

(8) UsableRulesProof (EQUIVALENT transformation)

For (infinitary) constructor rewriting [LOPSTR] we can delete all non-usable rules from R.

(9) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
UNIF_PAIRSK_IN_G(.(w(T148), .(w(T148), T149))) → UNIF_PAIRSK_IN_G(T149)
UNIF_PAIRSK_IN_G(.(black, .(w(T155), T156))) → UNIF_PAIRSK_IN_G(T156)
UNIF_PAIRSK_IN_G(.(w(T159), .(black, T160))) → UNIF_PAIRSK_IN_G(T160)

R is empty.
The argument filtering Pi contains the following mapping:
.(x1, x2)  =  .(x1, x2)
black  =  black
w(x1)  =  w
UNIF_PAIRSK_IN_G(x1)  =  UNIF_PAIRSK_IN_G(x1)

We have to consider all (P,R,Pi)-chains

(10) PiDPToQDPProof (SOUND transformation)

Transforming (infinitary) constructor rewriting Pi-DP problem [LOPSTR] into ordinary QDP problem [LPAR04] by application of Pi.

(11) Obligation:

Q DP problem:
The TRS P consists of the following rules:

UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
UNIF_PAIRSK_IN_G(.(w, .(w, T149))) → UNIF_PAIRSK_IN_G(T149)
UNIF_PAIRSK_IN_G(.(black, .(w, T156))) → UNIF_PAIRSK_IN_G(T156)
UNIF_PAIRSK_IN_G(.(w, .(black, T160))) → UNIF_PAIRSK_IN_G(T160)

R is empty.
Q is empty.
We have to consider all (P,Q,R)-chains.

(12) QDPSizeChangeProof (EQUIVALENT transformation)

By using the subterm criterion [SUBTERM_CRITERION] together with the size-change analysis [AAECC05] we have proven that there are no infinite chains for this DP problem.

From the DPs we obtained the following set of size-change graphs:

  • UNIF_PAIRSK_IN_G(.(black, .(black, T150))) → UNIF_PAIRSK_IN_G(T150)
    The graph contains the following edges 1 > 1

  • UNIF_PAIRSK_IN_G(.(w, .(w, T149))) → UNIF_PAIRSK_IN_G(T149)
    The graph contains the following edges 1 > 1

  • UNIF_PAIRSK_IN_G(.(black, .(w, T156))) → UNIF_PAIRSK_IN_G(T156)
    The graph contains the following edges 1 > 1

  • UNIF_PAIRSK_IN_G(.(w, .(black, T160))) → UNIF_PAIRSK_IN_G(T160)
    The graph contains the following edges 1 > 1

(13) YES

(14) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
UNIF_LINESI_IN_GG(x1, x2)  =  UNIF_LINESI_IN_GG(x1, x2)
PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)  =  PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)
U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)

We have to consider all (P,R,Pi)-chains

(15) UsableRulesProof (EQUIVALENT transformation)

For (infinitary) constructor rewriting [LOPSTR] we can delete all non-usable rules from R.

(16) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))

The TRS R consists of the following rules:

unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))

The argument filtering Pi contains the following mapping:
.(x1, x2)  =  .(x1, x2)
[]  =  []
black  =  black
w(x1)  =  w
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
UNIF_LINESI_IN_GG(x1, x2)  =  UNIF_LINESI_IN_GG(x1, x2)
PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)  =  PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)
U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)  =  U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)

We have to consider all (P,R,Pi)-chains

(17) PiDPToQDPProof (SOUND transformation)

Transforming (infinitary) constructor rewriting Pi-DP problem [LOPSTR] into ordinary QDP problem [LPAR04] by application of Pi.

(18) Obligation:

Q DP problem:
The TRS P consists of the following rules:

UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))

The TRS R consists of the following rules:

unif_pairsL_in_gg(w, .(w, T131)) → U13_gg(T131, unif_pairsK_in_g(T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
unif_pairsL_in_gg(black, .(w, T167)) → U15_gg(T167, unif_pairsK_in_g(T167))
unif_pairsL_in_gg(w, .(black, T171)) → U16_gg(T171, unif_pairsK_in_g(T171))
U13_gg(T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w, .(w, T131))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
U15_gg(T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w, T167))
U16_gg(T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w, .(black, T171))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w, .(w, T149))) → U9_g(T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w, T156))) → U11_g(T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w, .(black, T160))) → U12_g(T160, unif_pairsK_in_g(T160))
U9_g(T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w, .(w, T149)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U11_g(T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w, T156)))
U12_g(T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w, .(black, T160)))

The set Q consists of the following terms:

unif_pairsL_in_gg(x0, x1)
U13_gg(x0, x1)
U14_gg(x0, x1)
U15_gg(x0, x1)
U16_gg(x0, x1)
unif_pairsK_in_g(x0)
U9_g(x0, x1)
U10_g(x0, x1)
U11_g(x0, x1)
U12_g(x0, x1)

We have to consider all (P,Q,R)-chains.

(19) QDPOrderProof (EQUIVALENT transformation)

We use the reduction pair processor [LPAR04,JAR06].


The following pairs can be oriented strictly and are deleted.


UNIF_LINESI_IN_GG(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → PJ_IN_GGGGGG(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)
The remaining pairs can at least be oriented weakly.
Used ordering: Polynomial interpretation [POLO]:

POL(.(x1, x2)) = 1 + x2   
POL(PJ_IN_GGGGGG(x1, x2, x3, x4, x5, x6)) = 1 + x6   
POL(U10_g(x1, x2)) = 0   
POL(U11_g(x1, x2)) = 0   
POL(U12_g(x1, x2)) = 0   
POL(U13_gg(x1, x2)) = 0   
POL(U14_gg(x1, x2)) = 0   
POL(U15_gg(x1, x2)) = 0   
POL(U16_gg(x1, x2)) = 0   
POL(U25_GGGGGG(x1, x2, x3, x4, x5, x6, x7)) = 1 + x6   
POL(U9_g(x1, x2)) = 0   
POL(UNIF_LINESI_IN_GG(x1, x2)) = x2   
POL([]) = 0   
POL(black) = 0   
POL(unif_pairsK_in_g(x1)) = 0   
POL(unif_pairsK_out_g(x1)) = 0   
POL(unif_pairsL_in_gg(x1, x2)) = 0   
POL(unif_pairsL_out_gg(x1, x2)) = 0   
POL(w) = 0   

The following usable rules [FROCOS05] with respect to the argument filtering of the ordering [JAR06] were oriented:
none

(20) Obligation:

Q DP problem:
The TRS P consists of the following rules:

PJ_IN_GGGGGG(T103, T109, T110, T111, T112, T113) → U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_GGGGGG(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → UNIF_LINESI_IN_GG(.(T110, T111), .(T112, T113))

The TRS R consists of the following rules:

unif_pairsL_in_gg(w, .(w, T131)) → U13_gg(T131, unif_pairsK_in_g(T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
unif_pairsL_in_gg(black, .(w, T167)) → U15_gg(T167, unif_pairsK_in_g(T167))
unif_pairsL_in_gg(w, .(black, T171)) → U16_gg(T171, unif_pairsK_in_g(T171))
U13_gg(T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w, .(w, T131))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
U15_gg(T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w, T167))
U16_gg(T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w, .(black, T171))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w, .(w, T149))) → U9_g(T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w, T156))) → U11_g(T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w, .(black, T160))) → U12_g(T160, unif_pairsK_in_g(T160))
U9_g(T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w, .(w, T149)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U11_g(T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w, T156)))
U12_g(T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w, .(black, T160)))

The set Q consists of the following terms:

unif_pairsL_in_gg(x0, x1)
U13_gg(x0, x1)
U14_gg(x0, x1)
U15_gg(x0, x1)
U16_gg(x0, x1)
unif_pairsK_in_g(x0)
U9_g(x0, x1)
U10_g(x0, x1)
U11_g(x0, x1)
U12_g(x0, x1)

We have to consider all (P,Q,R)-chains.

(21) DependencyGraphProof (EQUIVALENT transformation)

The approximation of the Dependency Graph [LPAR04,FROCOS05,EDGSTAR] contains 0 SCCs with 2 less nodes.

(22) TRUE

(23) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
UNIF_MATRXG_IN_GG(x1, x2)  =  UNIF_MATRXG_IN_GG(x1, x2)
PH_IN_GGG(x1, x2, x3)  =  PH_IN_GGG(x1, x2, x3)
U23_GGG(x1, x2, x3, x4)  =  U23_GGG(x1, x2, x3, x4)

We have to consider all (P,R,Pi)-chains

(24) UsableRulesProof (EQUIVALENT transformation)

For (infinitary) constructor rewriting [LOPSTR] we can delete all non-usable rules from R.

(25) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)

The TRS R consists of the following rules:

unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))

The argument filtering Pi contains the following mapping:
.(x1, x2)  =  .(x1, x2)
[]  =  []
black  =  black
w(x1)  =  w
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
UNIF_MATRXG_IN_GG(x1, x2)  =  UNIF_MATRXG_IN_GG(x1, x2)
PH_IN_GGG(x1, x2, x3)  =  PH_IN_GGG(x1, x2, x3)
U23_GGG(x1, x2, x3, x4)  =  U23_GGG(x1, x2, x3, x4)

We have to consider all (P,R,Pi)-chains

(26) PiDPToQDPProof (SOUND transformation)

Transforming (infinitary) constructor rewriting Pi-DP problem [LOPSTR] into ordinary QDP problem [LPAR04] by application of Pi.

(27) Obligation:

Q DP problem:
The TRS P consists of the following rules:

UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)

The TRS R consists of the following rules:

unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_pairsL_in_gg(w, .(w, T131)) → U13_gg(T131, unif_pairsK_in_g(T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
unif_pairsL_in_gg(black, .(w, T167)) → U15_gg(T167, unif_pairsK_in_g(T167))
unif_pairsL_in_gg(w, .(black, T171)) → U16_gg(T171, unif_pairsK_in_g(T171))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U13_gg(T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w, .(w, T131))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
U15_gg(T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w, T167))
U16_gg(T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w, .(black, T171))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w, .(w, T149))) → U9_g(T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w, T156))) → U11_g(T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w, .(black, T160))) → U12_g(T160, unif_pairsK_in_g(T160))
U9_g(T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w, .(w, T149)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U11_g(T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w, T156)))
U12_g(T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w, .(black, T160)))

The set Q consists of the following terms:

unif_linesI_in_gg(x0, x1)
U8_gg(x0, x1, x2, x3, x4, x5, x6)
pJ_in_gggggg(x0, x1, x2, x3, x4, x5)
U25_gggggg(x0, x1, x2, x3, x4, x5, x6)
unif_pairsL_in_gg(x0, x1)
U26_gggggg(x0, x1, x2, x3, x4, x5, x6)
U13_gg(x0, x1)
U14_gg(x0, x1)
U15_gg(x0, x1)
U16_gg(x0, x1)
unif_pairsK_in_g(x0)
U9_g(x0, x1)
U10_g(x0, x1)
U11_g(x0, x1)
U12_g(x0, x1)

We have to consider all (P,Q,R)-chains.

(28) QDPSizeChangeProof (EQUIVALENT transformation)

By using the subterm criterion [SUBTERM_CRITERION] together with the size-change analysis [AAECC05] we have proven that there are no infinite chains for this DP problem.

From the DPs we obtained the following set of size-change graphs:

  • PH_IN_GGG(T56, T65, T66) → U23_GGG(T56, T65, T66, unif_linesI_in_gg(T56, T65))
    The graph contains the following edges 1 >= 1, 2 >= 2, 3 >= 3

  • U23_GGG(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → UNIF_MATRXG_IN_GG(T65, T66)
    The graph contains the following edges 2 >= 1, 4 > 1, 3 >= 2

  • UNIF_MATRXG_IN_GG(T56, .(T57, T58)) → PH_IN_GGG(T56, T57, T58)
    The graph contains the following edges 1 >= 1, 2 > 2, 2 > 3

(29) YES

(30) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → PF_IN_GAGA(T26, X77, T27, X78)
PF_IN_GAGA(T26, T28, T27, X78) → U21_GAGA(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27, X78)
VARMATE_IN_GA(.(black, T33), .(black, X93)) → VARMATE_IN_GA(T33, X93)
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → VARMATE_IN_GA(T36, X108)
PF_IN_GAGA(T26, T28, T27, X78) → VARMATE_IN_GA(T26, T28)

The TRS R consists of the following rules:

shapesA_in_ga(.(T15, T16), T6) → U1_ga(T15, T16, T6, pB_in_gaga(T15, X47, T16, X48))
pB_in_gaga(T15, T17, T16, X48) → U17_gaga(T15, T17, T16, X48, varmatE_in_ga(T15, T17))
varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U17_gaga(T15, T17, T16, X48, varmatE_out_ga(T15, T17)) → U18_gaga(T15, T17, T16, X48, pD_in_gag(T16, X48, T17))
pD_in_gag(T16, T37, T17) → U19_gag(T16, T37, T17, varmatE_in_ga(T16, T37))
U19_gag(T16, T37, T17, varmatE_out_ga(T16, T37)) → U20_gag(T16, T37, T17, unif_matrxG_in_gg(T17, T37))
unif_matrxG_in_gg(T56, .(T57, T58)) → U7_gg(T56, T57, T58, pH_in_ggg(T56, T57, T58))
pH_in_ggg(T56, T65, T66) → U23_ggg(T56, T65, T66, unif_linesI_in_gg(T56, T65))
unif_linesI_in_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108))) → U8_gg(T103, T104, T107, T105, T106, T108, pJ_in_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108))
pJ_in_gggggg(T103, T109, T110, T111, T112, T113) → U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_in_gg(T103, T109))
unif_pairsL_in_gg(w(T130), .(w(T130), T131)) → U13_gg(T130, T131, unif_pairsK_in_g(T131))
unif_pairsK_in_g([]) → unif_pairsK_out_g([])
unif_pairsK_in_g(.(w(T148), .(w(T148), T149))) → U9_g(T148, T149, unif_pairsK_in_g(T149))
unif_pairsK_in_g(.(black, .(black, T150))) → U10_g(T150, unif_pairsK_in_g(T150))
unif_pairsK_in_g(.(black, .(w(T155), T156))) → U11_g(T155, T156, unif_pairsK_in_g(T156))
unif_pairsK_in_g(.(w(T159), .(black, T160))) → U12_g(T159, T160, unif_pairsK_in_g(T160))
U12_g(T159, T160, unif_pairsK_out_g(T160)) → unif_pairsK_out_g(.(w(T159), .(black, T160)))
U11_g(T155, T156, unif_pairsK_out_g(T156)) → unif_pairsK_out_g(.(black, .(w(T155), T156)))
U10_g(T150, unif_pairsK_out_g(T150)) → unif_pairsK_out_g(.(black, .(black, T150)))
U9_g(T148, T149, unif_pairsK_out_g(T149)) → unif_pairsK_out_g(.(w(T148), .(w(T148), T149)))
U13_gg(T130, T131, unif_pairsK_out_g(T131)) → unif_pairsL_out_gg(w(T130), .(w(T130), T131))
unif_pairsL_in_gg(black, .(black, T161)) → U14_gg(T161, unif_pairsK_in_g(T161))
U14_gg(T161, unif_pairsK_out_g(T161)) → unif_pairsL_out_gg(black, .(black, T161))
unif_pairsL_in_gg(black, .(w(T166), T167)) → U15_gg(T166, T167, unif_pairsK_in_g(T167))
U15_gg(T166, T167, unif_pairsK_out_g(T167)) → unif_pairsL_out_gg(black, .(w(T166), T167))
unif_pairsL_in_gg(w(T170), .(black, T171)) → U16_gg(T170, T171, unif_pairsK_in_g(T171))
U16_gg(T170, T171, unif_pairsK_out_g(T171)) → unif_pairsL_out_gg(w(T170), .(black, T171))
U25_gggggg(T103, T109, T110, T111, T112, T113, unif_pairsL_out_gg(T103, T109)) → U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_in_gg(.(T110, T111), .(T112, T113)))
unif_linesI_in_gg(.(T182, []), .(T183, [])) → unif_linesI_out_gg(.(T182, []), .(T183, []))
U26_gggggg(T103, T109, T110, T111, T112, T113, unif_linesI_out_gg(.(T110, T111), .(T112, T113))) → pJ_out_gggggg(T103, T109, T110, T111, T112, T113)
U8_gg(T103, T104, T107, T105, T106, T108, pJ_out_gggggg(T103, .(T104, .(T105, .(T106, .(T103, .(T105, .(T104, .(T106, .(T103, .(T106, .(T104, .(T105, []))))))))))), T104, T107, T106, T108)) → unif_linesI_out_gg(.(T103, .(T104, T107)), .(T105, .(T106, T108)))
U23_ggg(T56, T65, T66, unif_linesI_out_gg(T56, T65)) → U24_ggg(T56, T65, T66, unif_matrxG_in_gg(T65, T66))
unif_matrxG_in_gg(T189, []) → unif_matrxG_out_gg(T189, [])
U24_ggg(T56, T65, T66, unif_matrxG_out_gg(T65, T66)) → pH_out_ggg(T56, T65, T66)
U7_gg(T56, T57, T58, pH_out_ggg(T56, T57, T58)) → unif_matrxG_out_gg(T56, .(T57, T58))
U20_gag(T16, T37, T17, unif_matrxG_out_gg(T17, T37)) → pD_out_gag(T16, T37, T17)
U18_gaga(T15, T17, T16, X48, pD_out_gag(T16, X48, T17)) → pB_out_gaga(T15, T17, T16, X48)
U1_ga(T15, T16, T6, pB_out_gaga(T15, X47, T16, X48)) → shapesA_out_ga(.(T15, T16), T6)
shapesA_in_ga(.(black, T194), T6) → U2_ga(T194, T6, pC_in_ga(T194, X245))
pC_in_ga(T194, T195) → U27_ga(T194, T195, varmatE_in_ga(T194, T195))
U27_ga(T194, T195, varmatE_out_ga(T194, T195)) → U28_ga(T194, T195, unif_matrxM_in_g(T195))
unif_matrxM_in_g([]) → unif_matrxM_out_g([])
U28_ga(T194, T195, unif_matrxM_out_g(T195)) → pC_out_ga(T194, T195)
U2_ga(T194, T6, pC_out_ga(T194, X245)) → shapesA_out_ga(.(black, T194), T6)
shapesA_in_ga(.(white, T217), T6) → U3_ga(T217, T6, pD_in_gag(T217, X304, w(X303)))
U3_ga(T217, T6, pD_out_gag(T217, X304, w(X303))) → shapesA_out_ga(.(white, T217), T6)

The argument filtering Pi contains the following mapping:
shapesA_in_ga(x1, x2)  =  shapesA_in_ga(x1)
.(x1, x2)  =  .(x1, x2)
U1_ga(x1, x2, x3, x4)  =  U1_ga(x1, x2, x4)
pB_in_gaga(x1, x2, x3, x4)  =  pB_in_gaga(x1, x3)
U17_gaga(x1, x2, x3, x4, x5)  =  U17_gaga(x1, x3, x5)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
U18_gaga(x1, x2, x3, x4, x5)  =  U18_gaga(x1, x2, x3, x5)
pD_in_gag(x1, x2, x3)  =  pD_in_gag(x1, x3)
U19_gag(x1, x2, x3, x4)  =  U19_gag(x1, x3, x4)
U20_gag(x1, x2, x3, x4)  =  U20_gag(x1, x2, x3, x4)
unif_matrxG_in_gg(x1, x2)  =  unif_matrxG_in_gg(x1, x2)
U7_gg(x1, x2, x3, x4)  =  U7_gg(x1, x2, x3, x4)
pH_in_ggg(x1, x2, x3)  =  pH_in_ggg(x1, x2, x3)
U23_ggg(x1, x2, x3, x4)  =  U23_ggg(x1, x2, x3, x4)
unif_linesI_in_gg(x1, x2)  =  unif_linesI_in_gg(x1, x2)
U8_gg(x1, x2, x3, x4, x5, x6, x7)  =  U8_gg(x1, x2, x3, x4, x5, x6, x7)
pJ_in_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_in_gggggg(x1, x2, x3, x4, x5, x6)
U25_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U25_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_pairsL_in_gg(x1, x2)  =  unif_pairsL_in_gg(x1, x2)
U13_gg(x1, x2, x3)  =  U13_gg(x2, x3)
unif_pairsK_in_g(x1)  =  unif_pairsK_in_g(x1)
unif_pairsK_out_g(x1)  =  unif_pairsK_out_g(x1)
U9_g(x1, x2, x3)  =  U9_g(x2, x3)
U10_g(x1, x2)  =  U10_g(x1, x2)
U11_g(x1, x2, x3)  =  U11_g(x2, x3)
U12_g(x1, x2, x3)  =  U12_g(x2, x3)
unif_pairsL_out_gg(x1, x2)  =  unif_pairsL_out_gg(x1, x2)
U14_gg(x1, x2)  =  U14_gg(x1, x2)
U15_gg(x1, x2, x3)  =  U15_gg(x2, x3)
U16_gg(x1, x2, x3)  =  U16_gg(x2, x3)
U26_gggggg(x1, x2, x3, x4, x5, x6, x7)  =  U26_gggggg(x1, x2, x3, x4, x5, x6, x7)
unif_linesI_out_gg(x1, x2)  =  unif_linesI_out_gg(x1, x2)
pJ_out_gggggg(x1, x2, x3, x4, x5, x6)  =  pJ_out_gggggg(x1, x2, x3, x4, x5, x6)
U24_ggg(x1, x2, x3, x4)  =  U24_ggg(x1, x2, x3, x4)
unif_matrxG_out_gg(x1, x2)  =  unif_matrxG_out_gg(x1, x2)
pH_out_ggg(x1, x2, x3)  =  pH_out_ggg(x1, x2, x3)
pD_out_gag(x1, x2, x3)  =  pD_out_gag(x1, x2, x3)
pB_out_gaga(x1, x2, x3, x4)  =  pB_out_gaga(x1, x2, x3, x4)
shapesA_out_ga(x1, x2)  =  shapesA_out_ga(x1)
U2_ga(x1, x2, x3)  =  U2_ga(x1, x3)
pC_in_ga(x1, x2)  =  pC_in_ga(x1)
U27_ga(x1, x2, x3)  =  U27_ga(x1, x3)
U28_ga(x1, x2, x3)  =  U28_ga(x1, x2, x3)
unif_matrxM_in_g(x1)  =  unif_matrxM_in_g(x1)
unif_matrxM_out_g(x1)  =  unif_matrxM_out_g(x1)
pC_out_ga(x1, x2)  =  pC_out_ga(x1, x2)
U3_ga(x1, x2, x3)  =  U3_ga(x1, x3)
VARMATE_IN_GA(x1, x2)  =  VARMATE_IN_GA(x1)
PF_IN_GAGA(x1, x2, x3, x4)  =  PF_IN_GAGA(x1, x3)
U21_GAGA(x1, x2, x3, x4, x5)  =  U21_GAGA(x1, x3, x5)

We have to consider all (P,R,Pi)-chains

(31) UsableRulesProof (EQUIVALENT transformation)

For (infinitary) constructor rewriting [LOPSTR] we can delete all non-usable rules from R.

(32) Obligation:

Pi DP problem:
The TRS P consists of the following rules:

VARMATE_IN_GA(.(T26, T27), .(X77, X78)) → PF_IN_GAGA(T26, X77, T27, X78)
PF_IN_GAGA(T26, T28, T27, X78) → U21_GAGA(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
U21_GAGA(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27, X78)
VARMATE_IN_GA(.(black, T33), .(black, X93)) → VARMATE_IN_GA(T33, X93)
VARMATE_IN_GA(.(white, T36), .(w(X107), X108)) → VARMATE_IN_GA(T36, X108)
PF_IN_GAGA(T26, T28, T27, X78) → VARMATE_IN_GA(T26, T28)

The TRS R consists of the following rules:

varmatE_in_ga([], []) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27), .(X77, X78)) → U4_ga(T26, T27, X77, X78, pF_in_gaga(T26, X77, T27, X78))
varmatE_in_ga(.(black, T33), .(black, X93)) → U5_ga(T33, X93, varmatE_in_ga(T33, X93))
varmatE_in_ga(.(white, T36), .(w(X107), X108)) → U6_ga(T36, X107, X108, varmatE_in_ga(T36, X108))
U4_ga(T26, T27, X77, X78, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U5_ga(T33, X93, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U6_ga(T36, X107, X108, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w(X107), X108))
pF_in_gaga(T26, T28, T27, X78) → U21_gaga(T26, T28, T27, X78, varmatE_in_ga(T26, T28))
U21_gaga(T26, T28, T27, X78, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, X78, varmatE_in_ga(T27, X78))
U22_gaga(T26, T28, T27, X78, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)

The argument filtering Pi contains the following mapping:
.(x1, x2)  =  .(x1, x2)
varmatE_in_ga(x1, x2)  =  varmatE_in_ga(x1)
[]  =  []
varmatE_out_ga(x1, x2)  =  varmatE_out_ga(x1, x2)
U4_ga(x1, x2, x3, x4, x5)  =  U4_ga(x1, x2, x5)
pF_in_gaga(x1, x2, x3, x4)  =  pF_in_gaga(x1, x3)
U21_gaga(x1, x2, x3, x4, x5)  =  U21_gaga(x1, x3, x5)
black  =  black
U5_ga(x1, x2, x3)  =  U5_ga(x1, x3)
white  =  white
U6_ga(x1, x2, x3, x4)  =  U6_ga(x1, x4)
w(x1)  =  w
U22_gaga(x1, x2, x3, x4, x5)  =  U22_gaga(x1, x2, x3, x5)
pF_out_gaga(x1, x2, x3, x4)  =  pF_out_gaga(x1, x2, x3, x4)
VARMATE_IN_GA(x1, x2)  =  VARMATE_IN_GA(x1)
PF_IN_GAGA(x1, x2, x3, x4)  =  PF_IN_GAGA(x1, x3)
U21_GAGA(x1, x2, x3, x4, x5)  =  U21_GAGA(x1, x3, x5)

We have to consider all (P,R,Pi)-chains

(33) PiDPToQDPProof (SOUND transformation)

Transforming (infinitary) constructor rewriting Pi-DP problem [LOPSTR] into ordinary QDP problem [LPAR04] by application of Pi.

(34) Obligation:

Q DP problem:
The TRS P consists of the following rules:

VARMATE_IN_GA(.(T26, T27)) → PF_IN_GAGA(T26, T27)
PF_IN_GAGA(T26, T27) → U21_GAGA(T26, T27, varmatE_in_ga(T26))
U21_GAGA(T26, T27, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27)
VARMATE_IN_GA(.(black, T33)) → VARMATE_IN_GA(T33)
VARMATE_IN_GA(.(white, T36)) → VARMATE_IN_GA(T36)
PF_IN_GAGA(T26, T27) → VARMATE_IN_GA(T26)

The TRS R consists of the following rules:

varmatE_in_ga([]) → varmatE_out_ga([], [])
varmatE_in_ga(.(T26, T27)) → U4_ga(T26, T27, pF_in_gaga(T26, T27))
varmatE_in_ga(.(black, T33)) → U5_ga(T33, varmatE_in_ga(T33))
varmatE_in_ga(.(white, T36)) → U6_ga(T36, varmatE_in_ga(T36))
U4_ga(T26, T27, pF_out_gaga(T26, X77, T27, X78)) → varmatE_out_ga(.(T26, T27), .(X77, X78))
U5_ga(T33, varmatE_out_ga(T33, X93)) → varmatE_out_ga(.(black, T33), .(black, X93))
U6_ga(T36, varmatE_out_ga(T36, X108)) → varmatE_out_ga(.(white, T36), .(w, X108))
pF_in_gaga(T26, T27) → U21_gaga(T26, T27, varmatE_in_ga(T26))
U21_gaga(T26, T27, varmatE_out_ga(T26, T28)) → U22_gaga(T26, T28, T27, varmatE_in_ga(T27))
U22_gaga(T26, T28, T27, varmatE_out_ga(T27, X78)) → pF_out_gaga(T26, T28, T27, X78)

The set Q consists of the following terms:

varmatE_in_ga(x0)
U4_ga(x0, x1, x2)
U5_ga(x0, x1)
U6_ga(x0, x1)
pF_in_gaga(x0, x1)
U21_gaga(x0, x1, x2)
U22_gaga(x0, x1, x2, x3)

We have to consider all (P,Q,R)-chains.

(35) QDPSizeChangeProof (EQUIVALENT transformation)

By using the subterm criterion [SUBTERM_CRITERION] together with the size-change analysis [AAECC05] we have proven that there are no infinite chains for this DP problem.

From the DPs we obtained the following set of size-change graphs:

  • PF_IN_GAGA(T26, T27) → VARMATE_IN_GA(T26)
    The graph contains the following edges 1 >= 1

  • PF_IN_GAGA(T26, T27) → U21_GAGA(T26, T27, varmatE_in_ga(T26))
    The graph contains the following edges 1 >= 1, 2 >= 2

  • VARMATE_IN_GA(.(T26, T27)) → PF_IN_GAGA(T26, T27)
    The graph contains the following edges 1 > 1, 1 > 2

  • U21_GAGA(T26, T27, varmatE_out_ga(T26, T28)) → VARMATE_IN_GA(T27)
    The graph contains the following edges 2 >= 1

  • VARMATE_IN_GA(.(black, T33)) → VARMATE_IN_GA(T33)
    The graph contains the following edges 1 > 1

  • VARMATE_IN_GA(.(white, T36)) → VARMATE_IN_GA(T36)
    The graph contains the following edges 1 > 1

(36) YES