0 QTRS
↳1 DependencyPairsProof (⇔)
↳2 QDP
↳3 DependencyGraphProof (⇔)
↳4 AND
↳5 QDP
↳6 QDPOrderProof (⇔)
↳7 QDP
↳8 QDPOrderProof (⇔)
↳9 QDP
↳10 PisEmptyProof (⇔)
↳11 TRUE
↳12 QDP
↳13 QDPOrderProof (⇔)
↳14 QDP
↳15 QDPOrderProof (⇔)
↳16 QDP
↳17 PisEmptyProof (⇔)
↳18 TRUE
↳19 QDP
↳20 QDPOrderProof (⇔)
↳21 QDP
↳22 QDPOrderProof (⇔)
↳23 QDP
↳24 QDPOrderProof (⇔)
↳25 QDP
↳26 QDPOrderProof (⇔)
↳27 QDP
↳28 PisEmptyProof (⇔)
↳29 TRUE
↳30 QDP
↳31 QDPOrderProof (⇔)
↳32 QDP
↳33 QDPOrderProof (⇔)
↳34 QDP
↳35 QDPOrderProof (⇔)
↳36 QDP
↳37 QDPOrderProof (⇔)
↳38 QDP
↳39 PisEmptyProof (⇔)
↳40 TRUE
↳41 QDP
↳42 QDPOrderProof (⇔)
↳43 QDP
↳44 QDPOrderProof (⇔)
↳45 QDP
↳46 QDPOrderProof (⇔)
↳47 QDP
↳48 QDPOrderProof (⇔)
↳49 QDP
↳50 PisEmptyProof (⇔)
↳51 TRUE
↳52 QDP
↳53 QDPOrderProof (⇔)
↳54 QDP
↳55 QDPOrderProof (⇔)
↳56 QDP
↳57 QDPOrderProof (⇔)
↳58 QDP
↳59 QDPOrderProof (⇔)
↳60 QDP
↳61 PisEmptyProof (⇔)
↳62 TRUE
↳63 QDP
↳64 QDPOrderProof (⇔)
↳65 QDP
↳66 QDPOrderProof (⇔)
↳67 QDP
↳68 PisEmptyProof (⇔)
↳69 TRUE
↳70 QDP
↳71 QDPOrderProof (⇔)
↳72 QDP
↳73 QDPOrderProof (⇔)
↳74 QDP
↳75 PisEmptyProof (⇔)
↳76 TRUE
↳77 QDP
↳78 QDPOrderProof (⇔)
↳79 QDP
↳80 QDPOrderProof (⇔)
↳81 QDP
↳82 PisEmptyProof (⇔)
↳83 TRUE
↳84 QDP
↳85 QDPOrderProof (⇔)
↳86 QDP
↳87 QDPOrderProof (⇔)
↳88 QDP
↳89 PisEmptyProof (⇔)
↳90 TRUE
↳91 QDP
↳92 QDPOrderProof (⇔)
↳93 QDP
↳94 QDPOrderProof (⇔)
↳95 QDP
↳96 PisEmptyProof (⇔)
↳97 TRUE
↳98 QDP
↳99 QDPOrderProof (⇔)
↳100 QDP
↳101 QDPOrderProof (⇔)
↳102 QDP
↳103 PisEmptyProof (⇔)
↳104 TRUE
↳105 QDP
↳106 QDPOrderProof (⇔)
↳107 QDP
↳108 QDPOrderProof (⇔)
↳109 QDP
↳110 PisEmptyProof (⇔)
↳111 TRUE
↳112 QDP
↳113 QDPOrderProof (⇔)
↳114 QDP
↳115 QDPOrderProof (⇔)
↳116 QDP
↳117 PisEmptyProof (⇔)
↳118 TRUE
↳119 QDP
↳120 QDPOrderProof (⇔)
↳121 QDP
↳122 QDPOrderProof (⇔)
↳123 QDP
↳124 QDPOrderProof (⇔)
↳125 QDP
↳126 QDPOrderProof (⇔)
↳127 QDP
↳128 PisEmptyProof (⇔)
↳129 TRUE
↳130 QDP
↳131 QDPOrderProof (⇔)
↳132 QDP
↳133 QDPOrderProof (⇔)
↳134 QDP
↳135 QDPOrderProof (⇔)
↳136 QDP
↳137 QDPOrderProof (⇔)
↳138 QDP
↳139 PisEmptyProof (⇔)
↳140 TRUE
↳141 QDP
↳142 QDPOrderProof (⇔)
↳143 QDP
↳144 QDPOrderProof (⇔)
↳145 QDP
↳146 QDPOrderProof (⇔)
↳147 QDP
↳148 QDPOrderProof (⇔)
↳149 QDP
↳150 PisEmptyProof (⇔)
↳151 TRUE
↳152 QDP
↳153 QDPOrderProof (⇔)
↳154 QDP
↳155 QDPOrderProof (⇔)
↳156 QDP
↳157 QDPOrderProof (⇔)
↳158 QDP
↳159 QDPOrderProof (⇔)
↳160 QDP
↳161 PisEmptyProof (⇔)
↳162 TRUE
↳163 QDP
↳164 QDPOrderProof (⇔)
↳165 QDP
↳166 QDPOrderProof (⇔)
↳167 QDP
↳168 PisEmptyProof (⇔)
↳169 TRUE
↳170 QDP
↳171 QDPOrderProof (⇔)
↳172 QDP
↳173 QDPOrderProof (⇔)
↳174 QDP
↳175 PisEmptyProof (⇔)
↳176 TRUE
↳177 QDP
↳178 QDPOrderProof (⇔)
↳179 QDP
↳180 QDPOrderProof (⇔)
↳181 QDP
↳182 PisEmptyProof (⇔)
↳183 TRUE
↳184 QDP
↳185 QDPOrderProof (⇔)
↳186 QDP
↳187 QDPOrderProof (⇔)
↳188 QDP
↳189 PisEmptyProof (⇔)
↳190 TRUE
↳191 QDP
↳192 QDPOrderProof (⇔)
↳193 QDP
↳194 QDPOrderProof (⇔)
↳195 QDP
↳196 PisEmptyProof (⇔)
↳197 TRUE
↳198 QDP
↳199 QDPOrderProof (⇔)
↳200 QDP
↳201 QDPOrderProof (⇔)
↳202 QDP
↳203 PisEmptyProof (⇔)
↳204 TRUE
↳205 QDP
↳206 QDPOrderProof (⇔)
↳207 QDP
↳208 QDPOrderProof (⇔)
↳209 QDP
↳210 PisEmptyProof (⇔)
↳211 TRUE
↳212 QDP
↳213 QDPOrderProof (⇔)
↳214 QDP
↳215 QDPOrderProof (⇔)
↳216 QDP
↳217 QDPOrderProof (⇔)
↳218 QDP
↳219 QDPOrderProof (⇔)
↳220 QDP
↳221 QDPOrderProof (⇔)
↳222 QDP
↳223 QDPOrderProof (⇔)
↳224 QDP
↳225 PisEmptyProof (⇔)
↳226 TRUE
↳227 QDP
↳228 QDPOrderProof (⇔)
↳229 QDP
↳230 QDPOrderProof (⇔)
↳231 QDP
↳232 QDPOrderProof (⇔)
↳233 QDP
↳234 QDPOrderProof (⇔)
↳235 QDP
↳236 QDPOrderProof (⇔)
↳237 QDP
↳238 QDPOrderProof (⇔)
↳239 QDP
↳240 PisEmptyProof (⇔)
↳241 TRUE
↳242 QDP
↳243 QDPOrderProof (⇔)
↳244 QDP
↳245 QDPOrderProof (⇔)
↳246 QDP
↳247 QDPOrderProof (⇔)
↳248 QDP
↳249 QDPOrderProof (⇔)
↳250 QDP
↳251 QDPOrderProof (⇔)
↳252 QDP
↳253 QDPOrderProof (⇔)
↳254 QDP
↳255 PisEmptyProof (⇔)
↳256 TRUE
↳257 QDP
↳258 QDPOrderProof (⇔)
↳259 QDP
↳260 QDPOrderProof (⇔)
↳261 QDP
↳262 QDPOrderProof (⇔)
↳263 QDP
↳264 QDPOrderProof (⇔)
↳265 QDP
↳266 QDPOrderProof (⇔)
↳267 QDP
↳268 QDPOrderProof (⇔)
↳269 QDP
↳270 PisEmptyProof (⇔)
↳271 TRUE
↳272 QDP
↳273 QDPOrderProof (⇔)
↳274 QDP
↳275 QDPOrderProof (⇔)
↳276 QDP
↳277 QDPOrderProof (⇔)
↳278 QDP
↳279 QDPOrderProof (⇔)
↳280 QDP
↳281 QDPOrderProof (⇔)
↳282 QDP
↳283 QDPOrderProof (⇔)
↳284 QDP
↳285 PisEmptyProof (⇔)
↳286 TRUE
↳287 QDP
↳288 QDPOrderProof (⇔)
↳289 QDP
↳290 QDPOrderProof (⇔)
↳291 QDP
↳292 QDPOrderProof (⇔)
↳293 QDP
↳294 QDPOrderProof (⇔)
↳295 QDP
↳296 QDPOrderProof (⇔)
↳297 QDP
↳298 QDPOrderProof (⇔)
↳299 QDP
↳300 PisEmptyProof (⇔)
↳301 TRUE
↳302 QDP
↳303 QDPOrderProof (⇔)
↳304 QDP
↳305 QDPOrderProof (⇔)
↳306 QDP
↳307 PisEmptyProof (⇔)
↳308 TRUE
↳309 QDP
↳310 QDPOrderProof (⇔)
↳311 QDP
↳312 QDPOrderProof (⇔)
↳313 QDP
↳314 PisEmptyProof (⇔)
↳315 TRUE
↳316 QDP
↳317 QDPOrderProof (⇔)
↳318 QDP
↳319 QDPOrderProof (⇔)
↳320 QDP
↳321 PisEmptyProof (⇔)
↳322 TRUE
↳323 QDP
↳324 QDPOrderProof (⇔)
↳325 QDP
↳326 QDPOrderProof (⇔)
↳327 QDP
↳328 PisEmptyProof (⇔)
↳329 TRUE
↳330 QDP
↳331 QDPOrderProof (⇔)
↳332 QDP
↳333 QDPOrderProof (⇔)
↳334 QDP
↳335 PisEmptyProof (⇔)
↳336 TRUE
↳337 QDP
↳338 QDPOrderProof (⇔)
↳339 QDP
↳340 QDPOrderProof (⇔)
↳341 QDP
↳342 PisEmptyProof (⇔)
↳343 TRUE
↳344 QDP
↳345 QDPOrderProof (⇔)
↳346 QDP
↳347 QDPOrderProof (⇔)
↳348 QDP
↳349 PisEmptyProof (⇔)
↳350 TRUE
↳351 QDP
↳352 QDPOrderProof (⇔)
↳353 QDP
↳354 QDPOrderProof (⇔)
↳355 QDP
↳356 QDPOrderProof (⇔)
↳357 QDP
↳358 QDPOrderProof (⇔)
↳359 QDP
↳360 PisEmptyProof (⇔)
↳361 TRUE
↳362 QDP
↳363 QDPOrderProof (⇔)
↳364 QDP
↳365 QDPOrderProof (⇔)
↳366 QDP
↳367 QDPOrderProof (⇔)
↳368 QDP
↳369 QDPOrderProof (⇔)
↳370 QDP
↳371 PisEmptyProof (⇔)
↳372 TRUE
↳373 QDP
↳374 QDPOrderProof (⇔)
↳375 QDP
↳376 QDPOrderProof (⇔)
↳377 QDP
↳378 QDPOrderProof (⇔)
↳379 QDP
↳380 QDPOrderProof (⇔)
↳381 QDP
↳382 PisEmptyProof (⇔)
↳383 TRUE
↳384 QDP
↳385 QDPOrderProof (⇔)
↳386 QDP
↳387 QDPOrderProof (⇔)
↳388 QDP
↳389 PisEmptyProof (⇔)
↳390 TRUE
↳391 QDP
↳392 QDPOrderProof (⇔)
↳393 QDP
↳394 QDPOrderProof (⇔)
↳395 QDP
↳396 PisEmptyProof (⇔)
↳397 TRUE
↳398 QDP
↳399 QDPOrderProof (⇔)
↳400 QDP
↳401 QDPOrderProof (⇔)
↳402 QDP
↳403 PisEmptyProof (⇔)
↳404 TRUE
↳405 QDP
↳406 QDPOrderProof (⇔)
↳407 QDP
↳408 QDPOrderProof (⇔)
↳409 QDP
↳410 PisEmptyProof (⇔)
↳411 TRUE
↳412 QDP
↳413 QDPOrderProof (⇔)
↳414 QDP
↳415 QDPOrderProof (⇔)
↳416 QDP
↳417 PisEmptyProof (⇔)
↳418 TRUE
↳419 QDP
↳420 QDPOrderProof (⇔)
↳421 QDP
↳422 QDPOrderProof (⇔)
↳423 QDP
↳424 PisEmptyProof (⇔)
↳425 TRUE
↳426 QDP
↳427 QDPOrderProof (⇔)
↳428 QDP
↳429 QDPOrderProof (⇔)
↳430 QDP
↳431 QDPOrderProof (⇔)
↳432 QDP
↳433 QDPOrderProof (⇔)
↳434 QDP
↳435 PisEmptyProof (⇔)
↳436 TRUE
↳437 QDP
↳438 QDPOrderProof (⇔)
↳439 QDP
↳440 QDPOrderProof (⇔)
↳441 QDP
↳442 PisEmptyProof (⇔)
↳443 TRUE
↳444 QDP
↳445 QDPOrderProof (⇔)
↳446 QDP
↳447 QDPOrderProof (⇔)
↳448 QDP
↳449 QDPOrderProof (⇔)
↳450 QDP
↳451 QDPOrderProof (⇔)
↳452 QDP
↳453 PisEmptyProof (⇔)
↳454 TRUE
↳455 QDP
↳456 QDPOrderProof (⇔)
↳457 QDP
↳458 QDPOrderProof (⇔)
↳459 QDP
↳460 PisEmptyProof (⇔)
↳461 TRUE
↳462 QDP
↳463 QDPOrderProof (⇔)
↳464 QDP
↳465 QDPOrderProof (⇔)
↳466 QDP
↳467 QDPOrderProof (⇔)
↳468 QDP
↳469 QDPOrderProof (⇔)
↳470 QDP
↳471 PisEmptyProof (⇔)
↳472 TRUE
↳473 QDP
↳474 QDPOrderProof (⇔)
↳475 QDP
↳476 QDPOrderProof (⇔)
↳477 QDP
↳478 QDPOrderProof (⇔)
↳479 QDP
↳480 QDPOrderProof (⇔)
↳481 QDP
↳482 PisEmptyProof (⇔)
↳483 TRUE
↳484 QDP
↳485 QDPOrderProof (⇔)
↳486 QDP
↳487 QDPOrderProof (⇔)
↳488 QDP
↳489 PisEmptyProof (⇔)
↳490 TRUE
↳491 QDP
↳492 QDPOrderProof (⇔)
↳493 QDP
↳494 QDPOrderProof (⇔)
↳495 QDP
↳496 QDPOrderProof (⇔)
↳497 QDP
↳498 QDPOrderProof (⇔)
↳499 QDP
↳500 QDPOrderProof (⇔)
↳501 QDP
↳502 QDPOrderProof (⇔)
↳503 QDP
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ACTIVE(zeros) → MARK(cons(0, zeros))
ACTIVE(zeros) → CONS(0, zeros)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
ACTIVE(U101(tt, V1, V2)) → U1021(isNatKind(V1), V1, V2)
ACTIVE(U101(tt, V1, V2)) → ISNATKIND(V1)
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
ACTIVE(U102(tt, V1, V2)) → U1031(isNatIListKind(V2), V1, V2)
ACTIVE(U102(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
ACTIVE(U103(tt, V1, V2)) → U1041(isNatIListKind(V2), V1, V2)
ACTIVE(U103(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
ACTIVE(U104(tt, V1, V2)) → U1051(isNat(V1), V2)
ACTIVE(U104(tt, V1, V2)) → ISNAT(V1)
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
ACTIVE(U105(tt, V2)) → U1061(isNatIList(V2))
ACTIVE(U105(tt, V2)) → ISNATILIST(V2)
ACTIVE(U106(tt)) → MARK(tt)
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
ACTIVE(U11(tt, V1)) → U121(isNatIListKind(V1), V1)
ACTIVE(U11(tt, V1)) → ISNATILISTKIND(V1)
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
ACTIVE(U111(tt, L, N)) → U1121(isNatIListKind(L), L, N)
ACTIVE(U111(tt, L, N)) → ISNATILISTKIND(L)
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
ACTIVE(U112(tt, L, N)) → U1131(isNat(N), L, N)
ACTIVE(U112(tt, L, N)) → ISNAT(N)
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
ACTIVE(U113(tt, L, N)) → U1141(isNatKind(N), L)
ACTIVE(U113(tt, L, N)) → ISNATKIND(N)
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
ACTIVE(U114(tt, L)) → S(length(L))
ACTIVE(U114(tt, L)) → LENGTH(L)
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
ACTIVE(U12(tt, V1)) → U131(isNatList(V1))
ACTIVE(U12(tt, V1)) → ISNATLIST(V1)
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
ACTIVE(U121(tt, IL)) → U1221(isNatIListKind(IL))
ACTIVE(U121(tt, IL)) → ISNATILISTKIND(IL)
ACTIVE(U122(tt)) → MARK(nil)
ACTIVE(U13(tt)) → MARK(tt)
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
ACTIVE(U131(tt, IL, M, N)) → U1321(isNatIListKind(IL), IL, M, N)
ACTIVE(U131(tt, IL, M, N)) → ISNATILISTKIND(IL)
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
ACTIVE(U132(tt, IL, M, N)) → U1331(isNat(M), IL, M, N)
ACTIVE(U132(tt, IL, M, N)) → ISNAT(M)
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
ACTIVE(U133(tt, IL, M, N)) → U1341(isNatKind(M), IL, M, N)
ACTIVE(U133(tt, IL, M, N)) → ISNATKIND(M)
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
ACTIVE(U134(tt, IL, M, N)) → U1351(isNat(N), IL, M, N)
ACTIVE(U134(tt, IL, M, N)) → ISNAT(N)
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
ACTIVE(U135(tt, IL, M, N)) → U1361(isNatKind(N), IL, M, N)
ACTIVE(U135(tt, IL, M, N)) → ISNATKIND(N)
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
ACTIVE(U136(tt, IL, M, N)) → CONS(N, take(M, IL))
ACTIVE(U136(tt, IL, M, N)) → TAKE(M, IL)
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
ACTIVE(U21(tt, V1)) → U221(isNatKind(V1), V1)
ACTIVE(U21(tt, V1)) → ISNATKIND(V1)
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
ACTIVE(U22(tt, V1)) → U231(isNat(V1))
ACTIVE(U22(tt, V1)) → ISNAT(V1)
ACTIVE(U23(tt)) → MARK(tt)
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
ACTIVE(U31(tt, V)) → U321(isNatIListKind(V), V)
ACTIVE(U31(tt, V)) → ISNATILISTKIND(V)
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
ACTIVE(U32(tt, V)) → U331(isNatList(V))
ACTIVE(U32(tt, V)) → ISNATLIST(V)
ACTIVE(U33(tt)) → MARK(tt)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
ACTIVE(U41(tt, V1, V2)) → U421(isNatKind(V1), V1, V2)
ACTIVE(U41(tt, V1, V2)) → ISNATKIND(V1)
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
ACTIVE(U42(tt, V1, V2)) → U431(isNatIListKind(V2), V1, V2)
ACTIVE(U42(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
ACTIVE(U43(tt, V1, V2)) → U441(isNatIListKind(V2), V1, V2)
ACTIVE(U43(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
ACTIVE(U44(tt, V1, V2)) → U451(isNat(V1), V2)
ACTIVE(U44(tt, V1, V2)) → ISNAT(V1)
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
ACTIVE(U45(tt, V2)) → U461(isNatIList(V2))
ACTIVE(U45(tt, V2)) → ISNATILIST(V2)
ACTIVE(U46(tt)) → MARK(tt)
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
ACTIVE(U51(tt, V2)) → U521(isNatIListKind(V2))
ACTIVE(U51(tt, V2)) → ISNATILISTKIND(V2)
ACTIVE(U52(tt)) → MARK(tt)
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
ACTIVE(U61(tt, V2)) → U621(isNatIListKind(V2))
ACTIVE(U61(tt, V2)) → ISNATILISTKIND(V2)
ACTIVE(U62(tt)) → MARK(tt)
ACTIVE(U71(tt)) → MARK(tt)
ACTIVE(U81(tt)) → MARK(tt)
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
ACTIVE(U91(tt, V1, V2)) → U921(isNatKind(V1), V1, V2)
ACTIVE(U91(tt, V1, V2)) → ISNATKIND(V1)
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
ACTIVE(U92(tt, V1, V2)) → U931(isNatIListKind(V2), V1, V2)
ACTIVE(U92(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
ACTIVE(U93(tt, V1, V2)) → U941(isNatIListKind(V2), V1, V2)
ACTIVE(U93(tt, V1, V2)) → ISNATILISTKIND(V2)
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
ACTIVE(U94(tt, V1, V2)) → U951(isNat(V1), V2)
ACTIVE(U94(tt, V1, V2)) → ISNAT(V1)
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
ACTIVE(U95(tt, V2)) → U961(isNatList(V2))
ACTIVE(U95(tt, V2)) → ISNATLIST(V2)
ACTIVE(U96(tt)) → MARK(tt)
ACTIVE(isNat(0)) → MARK(tt)
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
ACTIVE(isNat(length(V1))) → U111(isNatIListKind(V1), V1)
ACTIVE(isNat(length(V1))) → ISNATILISTKIND(V1)
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
ACTIVE(isNat(s(V1))) → U211(isNatKind(V1), V1)
ACTIVE(isNat(s(V1))) → ISNATKIND(V1)
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
ACTIVE(isNatIList(V)) → U311(isNatIListKind(V), V)
ACTIVE(isNatIList(V)) → ISNATILISTKIND(V)
ACTIVE(isNatIList(zeros)) → MARK(tt)
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
ACTIVE(isNatIList(cons(V1, V2))) → U411(isNatKind(V1), V1, V2)
ACTIVE(isNatIList(cons(V1, V2))) → ISNATKIND(V1)
ACTIVE(isNatIListKind(nil)) → MARK(tt)
ACTIVE(isNatIListKind(zeros)) → MARK(tt)
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
ACTIVE(isNatIListKind(cons(V1, V2))) → U511(isNatKind(V1), V2)
ACTIVE(isNatIListKind(cons(V1, V2))) → ISNATKIND(V1)
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
ACTIVE(isNatIListKind(take(V1, V2))) → U611(isNatKind(V1), V2)
ACTIVE(isNatIListKind(take(V1, V2))) → ISNATKIND(V1)
ACTIVE(isNatKind(0)) → MARK(tt)
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
ACTIVE(isNatKind(length(V1))) → U711(isNatIListKind(V1))
ACTIVE(isNatKind(length(V1))) → ISNATILISTKIND(V1)
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
ACTIVE(isNatKind(s(V1))) → U811(isNatKind(V1))
ACTIVE(isNatKind(s(V1))) → ISNATKIND(V1)
ACTIVE(isNatList(nil)) → MARK(tt)
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
ACTIVE(isNatList(cons(V1, V2))) → U911(isNatKind(V1), V1, V2)
ACTIVE(isNatList(cons(V1, V2))) → ISNATKIND(V1)
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
ACTIVE(isNatList(take(V1, V2))) → U1011(isNatKind(V1), V1, V2)
ACTIVE(isNatList(take(V1, V2))) → ISNATKIND(V1)
ACTIVE(length(nil)) → MARK(0)
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
ACTIVE(length(cons(N, L))) → U1111(isNatList(L), L, N)
ACTIVE(length(cons(N, L))) → ISNATLIST(L)
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
ACTIVE(take(0, IL)) → U1211(isNatIList(IL), IL)
ACTIVE(take(0, IL)) → ISNATILIST(IL)
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
ACTIVE(take(s(M), cons(N, IL))) → U1311(isNatIList(IL), IL, M, N)
ACTIVE(take(s(M), cons(N, IL))) → ISNATILIST(IL)
MARK(zeros) → ACTIVE(zeros)
MARK(cons(X1, X2)) → ACTIVE(cons(mark(X1), X2))
MARK(cons(X1, X2)) → CONS(mark(X1), X2)
MARK(cons(X1, X2)) → MARK(X1)
MARK(0) → ACTIVE(0)
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
MARK(U101(X1, X2, X3)) → U1011(mark(X1), X2, X3)
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(tt) → ACTIVE(tt)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
MARK(U102(X1, X2, X3)) → U1021(mark(X1), X2, X3)
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
MARK(U103(X1, X2, X3)) → U1031(mark(X1), X2, X3)
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
MARK(U104(X1, X2, X3)) → U1041(mark(X1), X2, X3)
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
MARK(U105(X1, X2)) → U1051(mark(X1), X2)
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
MARK(U106(X)) → ACTIVE(U106(mark(X)))
MARK(U106(X)) → U1061(mark(X))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
MARK(U11(X1, X2)) → U111(mark(X1), X2)
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
MARK(U12(X1, X2)) → U121(mark(X1), X2)
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
MARK(U111(X1, X2, X3)) → U1111(mark(X1), X2, X3)
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
MARK(U112(X1, X2, X3)) → U1121(mark(X1), X2, X3)
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
MARK(U113(X1, X2, X3)) → U1131(mark(X1), X2, X3)
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
MARK(U114(X1, X2)) → U1141(mark(X1), X2)
MARK(U114(X1, X2)) → MARK(X1)
MARK(s(X)) → ACTIVE(s(mark(X)))
MARK(s(X)) → S(mark(X))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
MARK(length(X)) → LENGTH(mark(X))
MARK(length(X)) → MARK(X)
MARK(U13(X)) → ACTIVE(U13(mark(X)))
MARK(U13(X)) → U131(mark(X))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
MARK(U121(X1, X2)) → U1211(mark(X1), X2)
MARK(U121(X1, X2)) → MARK(X1)
MARK(U122(X)) → ACTIVE(U122(mark(X)))
MARK(U122(X)) → U1221(mark(X))
MARK(U122(X)) → MARK(X)
MARK(nil) → ACTIVE(nil)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
MARK(U131(X1, X2, X3, X4)) → U1311(mark(X1), X2, X3, X4)
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
MARK(U132(X1, X2, X3, X4)) → U1321(mark(X1), X2, X3, X4)
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
MARK(U133(X1, X2, X3, X4)) → U1331(mark(X1), X2, X3, X4)
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
MARK(U134(X1, X2, X3, X4)) → U1341(mark(X1), X2, X3, X4)
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
MARK(U135(X1, X2, X3, X4)) → U1351(mark(X1), X2, X3, X4)
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
MARK(U136(X1, X2, X3, X4)) → U1361(mark(X1), X2, X3, X4)
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
MARK(take(X1, X2)) → TAKE(mark(X1), mark(X2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
MARK(U21(X1, X2)) → U211(mark(X1), X2)
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
MARK(U22(X1, X2)) → U221(mark(X1), X2)
MARK(U22(X1, X2)) → MARK(X1)
MARK(U23(X)) → ACTIVE(U23(mark(X)))
MARK(U23(X)) → U231(mark(X))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
MARK(U31(X1, X2)) → U311(mark(X1), X2)
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
MARK(U32(X1, X2)) → U321(mark(X1), X2)
MARK(U32(X1, X2)) → MARK(X1)
MARK(U33(X)) → ACTIVE(U33(mark(X)))
MARK(U33(X)) → U331(mark(X))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
MARK(U41(X1, X2, X3)) → U411(mark(X1), X2, X3)
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
MARK(U42(X1, X2, X3)) → U421(mark(X1), X2, X3)
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
MARK(U43(X1, X2, X3)) → U431(mark(X1), X2, X3)
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
MARK(U44(X1, X2, X3)) → U441(mark(X1), X2, X3)
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
MARK(U45(X1, X2)) → U451(mark(X1), X2)
MARK(U45(X1, X2)) → MARK(X1)
MARK(U46(X)) → ACTIVE(U46(mark(X)))
MARK(U46(X)) → U461(mark(X))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
MARK(U51(X1, X2)) → U511(mark(X1), X2)
MARK(U51(X1, X2)) → MARK(X1)
MARK(U52(X)) → ACTIVE(U52(mark(X)))
MARK(U52(X)) → U521(mark(X))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
MARK(U61(X1, X2)) → U611(mark(X1), X2)
MARK(U61(X1, X2)) → MARK(X1)
MARK(U62(X)) → ACTIVE(U62(mark(X)))
MARK(U62(X)) → U621(mark(X))
MARK(U62(X)) → MARK(X)
MARK(U71(X)) → ACTIVE(U71(mark(X)))
MARK(U71(X)) → U711(mark(X))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → U811(mark(X))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → U911(mark(X1), X2, X3)
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → U921(mark(X1), X2, X3)
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → U931(mark(X1), X2, X3)
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → U941(mark(X1), X2, X3)
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → U951(mark(X1), X2)
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → U961(mark(X))
MARK(U96(X)) → MARK(X)
CONS(mark(X1), X2) → CONS(X1, X2)
CONS(X1, mark(X2)) → CONS(X1, X2)
CONS(active(X1), X2) → CONS(X1, X2)
CONS(X1, active(X2)) → CONS(X1, X2)
U1011(mark(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, mark(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, mark(X3)) → U1011(X1, X2, X3)
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, active(X3)) → U1011(X1, X2, X3)
U1021(mark(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, mark(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, mark(X3)) → U1021(X1, X2, X3)
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, active(X3)) → U1021(X1, X2, X3)
ISNATKIND(mark(X)) → ISNATKIND(X)
ISNATKIND(active(X)) → ISNATKIND(X)
U1031(mark(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, mark(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, mark(X3)) → U1031(X1, X2, X3)
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, active(X3)) → U1031(X1, X2, X3)
ISNATILISTKIND(mark(X)) → ISNATILISTKIND(X)
ISNATILISTKIND(active(X)) → ISNATILISTKIND(X)
U1041(mark(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, mark(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, mark(X3)) → U1041(X1, X2, X3)
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, active(X3)) → U1041(X1, X2, X3)
U1051(mark(X1), X2) → U1051(X1, X2)
U1051(X1, mark(X2)) → U1051(X1, X2)
U1051(active(X1), X2) → U1051(X1, X2)
U1051(X1, active(X2)) → U1051(X1, X2)
ISNAT(mark(X)) → ISNAT(X)
ISNAT(active(X)) → ISNAT(X)
U1061(mark(X)) → U1061(X)
U1061(active(X)) → U1061(X)
ISNATILIST(mark(X)) → ISNATILIST(X)
ISNATILIST(active(X)) → ISNATILIST(X)
U111(mark(X1), X2) → U111(X1, X2)
U111(X1, mark(X2)) → U111(X1, X2)
U111(active(X1), X2) → U111(X1, X2)
U111(X1, active(X2)) → U111(X1, X2)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U1111(mark(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, mark(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, mark(X3)) → U1111(X1, X2, X3)
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, active(X3)) → U1111(X1, X2, X3)
U1121(mark(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, mark(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, mark(X3)) → U1121(X1, X2, X3)
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, active(X3)) → U1121(X1, X2, X3)
U1131(mark(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, mark(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, mark(X3)) → U1131(X1, X2, X3)
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, active(X3)) → U1131(X1, X2, X3)
U1141(mark(X1), X2) → U1141(X1, X2)
U1141(X1, mark(X2)) → U1141(X1, X2)
U1141(active(X1), X2) → U1141(X1, X2)
U1141(X1, active(X2)) → U1141(X1, X2)
S(mark(X)) → S(X)
S(active(X)) → S(X)
LENGTH(mark(X)) → LENGTH(X)
LENGTH(active(X)) → LENGTH(X)
U131(mark(X)) → U131(X)
U131(active(X)) → U131(X)
ISNATLIST(mark(X)) → ISNATLIST(X)
ISNATLIST(active(X)) → ISNATLIST(X)
U1211(mark(X1), X2) → U1211(X1, X2)
U1211(X1, mark(X2)) → U1211(X1, X2)
U1211(active(X1), X2) → U1211(X1, X2)
U1211(X1, active(X2)) → U1211(X1, X2)
U1221(mark(X)) → U1221(X)
U1221(active(X)) → U1221(X)
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, mark(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, mark(X4)) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, active(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, active(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, active(X4)) → U1311(X1, X2, X3, X4)
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, mark(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, mark(X4)) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, active(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, active(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, active(X4)) → U1321(X1, X2, X3, X4)
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, mark(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, mark(X4)) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, active(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, active(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, active(X4)) → U1331(X1, X2, X3, X4)
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, mark(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, mark(X4)) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, active(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, active(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, active(X4)) → U1341(X1, X2, X3, X4)
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, mark(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, mark(X4)) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, active(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, active(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, active(X4)) → U1351(X1, X2, X3, X4)
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, mark(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, mark(X4)) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, active(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, active(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, active(X4)) → U1361(X1, X2, X3, X4)
TAKE(mark(X1), X2) → TAKE(X1, X2)
TAKE(X1, mark(X2)) → TAKE(X1, X2)
TAKE(active(X1), X2) → TAKE(X1, X2)
TAKE(X1, active(X2)) → TAKE(X1, X2)
U211(mark(X1), X2) → U211(X1, X2)
U211(X1, mark(X2)) → U211(X1, X2)
U211(active(X1), X2) → U211(X1, X2)
U211(X1, active(X2)) → U211(X1, X2)
U221(mark(X1), X2) → U221(X1, X2)
U221(X1, mark(X2)) → U221(X1, X2)
U221(active(X1), X2) → U221(X1, X2)
U221(X1, active(X2)) → U221(X1, X2)
U231(mark(X)) → U231(X)
U231(active(X)) → U231(X)
U311(mark(X1), X2) → U311(X1, X2)
U311(X1, mark(X2)) → U311(X1, X2)
U311(active(X1), X2) → U311(X1, X2)
U311(X1, active(X2)) → U311(X1, X2)
U321(mark(X1), X2) → U321(X1, X2)
U321(X1, mark(X2)) → U321(X1, X2)
U321(active(X1), X2) → U321(X1, X2)
U321(X1, active(X2)) → U321(X1, X2)
U331(mark(X)) → U331(X)
U331(active(X)) → U331(X)
U411(mark(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, mark(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, mark(X3)) → U411(X1, X2, X3)
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, active(X3)) → U411(X1, X2, X3)
U421(mark(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, mark(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, mark(X3)) → U421(X1, X2, X3)
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, active(X3)) → U421(X1, X2, X3)
U431(mark(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, mark(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, mark(X3)) → U431(X1, X2, X3)
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, active(X3)) → U431(X1, X2, X3)
U441(mark(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, mark(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, mark(X3)) → U441(X1, X2, X3)
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, active(X3)) → U441(X1, X2, X3)
U451(mark(X1), X2) → U451(X1, X2)
U451(X1, mark(X2)) → U451(X1, X2)
U451(active(X1), X2) → U451(X1, X2)
U451(X1, active(X2)) → U451(X1, X2)
U461(mark(X)) → U461(X)
U461(active(X)) → U461(X)
U511(mark(X1), X2) → U511(X1, X2)
U511(X1, mark(X2)) → U511(X1, X2)
U511(active(X1), X2) → U511(X1, X2)
U511(X1, active(X2)) → U511(X1, X2)
U521(mark(X)) → U521(X)
U521(active(X)) → U521(X)
U611(mark(X1), X2) → U611(X1, X2)
U611(X1, mark(X2)) → U611(X1, X2)
U611(active(X1), X2) → U611(X1, X2)
U611(X1, active(X2)) → U611(X1, X2)
U621(mark(X)) → U621(X)
U621(active(X)) → U621(X)
U711(mark(X)) → U711(X)
U711(active(X)) → U711(X)
U811(mark(X)) → U811(X)
U811(active(X)) → U811(X)
U911(mark(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, mark(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, mark(X3)) → U911(X1, X2, X3)
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, active(X3)) → U911(X1, X2, X3)
U921(mark(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, mark(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, mark(X3)) → U921(X1, X2, X3)
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, active(X3)) → U921(X1, X2, X3)
U931(mark(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, mark(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, mark(X3)) → U931(X1, X2, X3)
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, active(X3)) → U931(X1, X2, X3)
U941(mark(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, mark(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, mark(X3)) → U941(X1, X2, X3)
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, active(X3)) → U941(X1, X2, X3)
U951(mark(X1), X2) → U951(X1, X2)
U951(X1, mark(X2)) → U951(X1, X2)
U951(active(X1), X2) → U951(X1, X2)
U951(X1, active(X2)) → U951(X1, X2)
U961(mark(X)) → U961(X)
U961(active(X)) → U961(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U961(active(X)) → U961(X)
U961(mark(X)) → U961(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U961(active(X)) → U961(X)
[U96^11, active1]
active1: [1]
U96^11: [1]
U961(mark(X)) → U961(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U961(mark(X)) → U961(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U951(X1, mark(X2)) → U951(X1, X2)
U951(mark(X1), X2) → U951(X1, X2)
U951(active(X1), X2) → U951(X1, X2)
U951(X1, active(X2)) → U951(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U951(X1, mark(X2)) → U951(X1, X2)
U951(mark(X1), X2) → U951(X1, X2)
[U95^12, mark1]
mark1: [1]
U95^12: [2,1]
U951(active(X1), X2) → U951(X1, X2)
U951(X1, active(X2)) → U951(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U951(active(X1), X2) → U951(X1, X2)
U951(X1, active(X2)) → U951(X1, X2)
[U95^12, active1]
active1: [1]
U95^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U941(X1, mark(X2), X3) → U941(X1, X2, X3)
U941(mark(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, X2, mark(X3)) → U941(X1, X2, X3)
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, active(X3)) → U941(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U941(X1, mark(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, mark(X3)) → U941(X1, X2, X3)
mark1 > U94^12
U94^12: [2,1]
mark1: [1]
U941(mark(X1), X2, X3) → U941(X1, X2, X3)
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, active(X3)) → U941(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U941(mark(X1), X2, X3) → U941(X1, X2, X3)
[U94^13, mark1]
mark1: [1]
U94^13: [3,2,1]
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
U941(X1, X2, active(X3)) → U941(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U941(X1, X2, active(X3)) → U941(X1, X2, X3)
active1 > U94^11
active1: [1]
U94^11: [1]
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U941(active(X1), X2, X3) → U941(X1, X2, X3)
U941(X1, active(X2), X3) → U941(X1, X2, X3)
[U94^13, active1]
active1: [1]
U94^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U931(X1, mark(X2), X3) → U931(X1, X2, X3)
U931(mark(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, X2, mark(X3)) → U931(X1, X2, X3)
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, active(X3)) → U931(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U931(X1, mark(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, mark(X3)) → U931(X1, X2, X3)
mark1 > U93^12
U93^12: [2,1]
mark1: [1]
U931(mark(X1), X2, X3) → U931(X1, X2, X3)
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, active(X3)) → U931(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U931(mark(X1), X2, X3) → U931(X1, X2, X3)
[U93^13, mark1]
U93^13: [3,2,1]
mark1: [1]
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
U931(X1, X2, active(X3)) → U931(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U931(X1, X2, active(X3)) → U931(X1, X2, X3)
active1 > U93^11
active1: [1]
U93^11: [1]
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U931(active(X1), X2, X3) → U931(X1, X2, X3)
U931(X1, active(X2), X3) → U931(X1, X2, X3)
[U93^13, active1]
active1: [1]
U93^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U921(X1, mark(X2), X3) → U921(X1, X2, X3)
U921(mark(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, X2, mark(X3)) → U921(X1, X2, X3)
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, active(X3)) → U921(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U921(X1, mark(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, mark(X3)) → U921(X1, X2, X3)
mark1 > U92^12
mark1: [1]
U92^12: [2,1]
U921(mark(X1), X2, X3) → U921(X1, X2, X3)
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, active(X3)) → U921(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U921(mark(X1), X2, X3) → U921(X1, X2, X3)
[U92^13, mark1]
mark1: [1]
U92^13: [3,2,1]
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
U921(X1, X2, active(X3)) → U921(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U921(X1, X2, active(X3)) → U921(X1, X2, X3)
active1 > U92^11
active1: [1]
U92^11: [1]
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U921(active(X1), X2, X3) → U921(X1, X2, X3)
U921(X1, active(X2), X3) → U921(X1, X2, X3)
[U92^13, active1]
active1: [1]
U92^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U911(X1, mark(X2), X3) → U911(X1, X2, X3)
U911(mark(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, X2, mark(X3)) → U911(X1, X2, X3)
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, active(X3)) → U911(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U911(X1, mark(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, mark(X3)) → U911(X1, X2, X3)
mark1 > U91^12
U91^12: [2,1]
mark1: [1]
U911(mark(X1), X2, X3) → U911(X1, X2, X3)
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, active(X3)) → U911(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U911(mark(X1), X2, X3) → U911(X1, X2, X3)
[U91^13, mark1]
U91^13: [3,2,1]
mark1: [1]
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
U911(X1, X2, active(X3)) → U911(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U911(X1, X2, active(X3)) → U911(X1, X2, X3)
active1 > U91^11
active1: [1]
U91^11: [1]
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U911(active(X1), X2, X3) → U911(X1, X2, X3)
U911(X1, active(X2), X3) → U911(X1, X2, X3)
[U91^13, active1]
U91^13: [3,2,1]
active1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U811(active(X)) → U811(X)
U811(mark(X)) → U811(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U811(active(X)) → U811(X)
[U81^11, active1]
active1: [1]
U81^11: [1]
U811(mark(X)) → U811(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U811(mark(X)) → U811(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U711(active(X)) → U711(X)
U711(mark(X)) → U711(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U711(active(X)) → U711(X)
[U71^11, active1]
active1: [1]
U71^11: [1]
U711(mark(X)) → U711(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U711(mark(X)) → U711(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U621(active(X)) → U621(X)
U621(mark(X)) → U621(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U621(active(X)) → U621(X)
[U62^11, active1]
active1: [1]
U62^11: [1]
U621(mark(X)) → U621(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U621(mark(X)) → U621(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U611(X1, mark(X2)) → U611(X1, X2)
U611(mark(X1), X2) → U611(X1, X2)
U611(active(X1), X2) → U611(X1, X2)
U611(X1, active(X2)) → U611(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U611(X1, mark(X2)) → U611(X1, X2)
U611(mark(X1), X2) → U611(X1, X2)
[U61^12, mark1]
U61^12: [2,1]
mark1: [1]
U611(active(X1), X2) → U611(X1, X2)
U611(X1, active(X2)) → U611(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U611(active(X1), X2) → U611(X1, X2)
U611(X1, active(X2)) → U611(X1, X2)
[U61^12, active1]
active1: [1]
U61^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U521(active(X)) → U521(X)
U521(mark(X)) → U521(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U521(active(X)) → U521(X)
[U52^11, active1]
U52^11: [1]
active1: [1]
U521(mark(X)) → U521(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U521(mark(X)) → U521(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U511(X1, mark(X2)) → U511(X1, X2)
U511(mark(X1), X2) → U511(X1, X2)
U511(active(X1), X2) → U511(X1, X2)
U511(X1, active(X2)) → U511(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U511(X1, mark(X2)) → U511(X1, X2)
U511(mark(X1), X2) → U511(X1, X2)
[U51^12, mark1]
U51^12: [2,1]
mark1: [1]
U511(active(X1), X2) → U511(X1, X2)
U511(X1, active(X2)) → U511(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U511(active(X1), X2) → U511(X1, X2)
U511(X1, active(X2)) → U511(X1, X2)
[U51^12, active1]
active1: [1]
U51^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U461(active(X)) → U461(X)
U461(mark(X)) → U461(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U461(active(X)) → U461(X)
[U46^11, active1]
active1: [1]
U46^11: [1]
U461(mark(X)) → U461(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U461(mark(X)) → U461(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U451(X1, mark(X2)) → U451(X1, X2)
U451(mark(X1), X2) → U451(X1, X2)
U451(active(X1), X2) → U451(X1, X2)
U451(X1, active(X2)) → U451(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U451(X1, mark(X2)) → U451(X1, X2)
U451(mark(X1), X2) → U451(X1, X2)
[U45^12, mark1]
U45^12: [2,1]
mark1: [1]
U451(active(X1), X2) → U451(X1, X2)
U451(X1, active(X2)) → U451(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U451(active(X1), X2) → U451(X1, X2)
U451(X1, active(X2)) → U451(X1, X2)
[U45^12, active1]
active1: [1]
U45^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U441(X1, mark(X2), X3) → U441(X1, X2, X3)
U441(mark(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, X2, mark(X3)) → U441(X1, X2, X3)
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, active(X3)) → U441(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U441(X1, mark(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, mark(X3)) → U441(X1, X2, X3)
mark1 > U44^12
mark1: [1]
U44^12: [2,1]
U441(mark(X1), X2, X3) → U441(X1, X2, X3)
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, active(X3)) → U441(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U441(mark(X1), X2, X3) → U441(X1, X2, X3)
[U44^13, mark1]
mark1: [1]
U44^13: [3,2,1]
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
U441(X1, X2, active(X3)) → U441(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U441(X1, X2, active(X3)) → U441(X1, X2, X3)
active1 > U44^11
active1: [1]
U44^11: [1]
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U441(active(X1), X2, X3) → U441(X1, X2, X3)
U441(X1, active(X2), X3) → U441(X1, X2, X3)
[U44^13, active1]
active1: [1]
U44^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U431(X1, mark(X2), X3) → U431(X1, X2, X3)
U431(mark(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, X2, mark(X3)) → U431(X1, X2, X3)
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, active(X3)) → U431(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U431(X1, mark(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, mark(X3)) → U431(X1, X2, X3)
mark1 > U43^12
U43^12: [2,1]
mark1: [1]
U431(mark(X1), X2, X3) → U431(X1, X2, X3)
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, active(X3)) → U431(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U431(mark(X1), X2, X3) → U431(X1, X2, X3)
[U43^13, mark1]
U43^13: [3,2,1]
mark1: [1]
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
U431(X1, X2, active(X3)) → U431(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U431(X1, X2, active(X3)) → U431(X1, X2, X3)
active1 > U43^11
active1: [1]
U43^11: [1]
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U431(active(X1), X2, X3) → U431(X1, X2, X3)
U431(X1, active(X2), X3) → U431(X1, X2, X3)
[U43^13, active1]
active1: [1]
U43^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U421(X1, mark(X2), X3) → U421(X1, X2, X3)
U421(mark(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, X2, mark(X3)) → U421(X1, X2, X3)
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, active(X3)) → U421(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U421(X1, mark(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, mark(X3)) → U421(X1, X2, X3)
mark1 > U42^12
U42^12: [2,1]
mark1: [1]
U421(mark(X1), X2, X3) → U421(X1, X2, X3)
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, active(X3)) → U421(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U421(mark(X1), X2, X3) → U421(X1, X2, X3)
[U42^13, mark1]
U42^13: [3,2,1]
mark1: [1]
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
U421(X1, X2, active(X3)) → U421(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U421(X1, X2, active(X3)) → U421(X1, X2, X3)
active1 > U42^11
active1: [1]
U42^11: [1]
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U421(active(X1), X2, X3) → U421(X1, X2, X3)
U421(X1, active(X2), X3) → U421(X1, X2, X3)
[U42^13, active1]
active1: [1]
U42^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U411(X1, mark(X2), X3) → U411(X1, X2, X3)
U411(mark(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, X2, mark(X3)) → U411(X1, X2, X3)
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, active(X3)) → U411(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U411(X1, mark(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, mark(X3)) → U411(X1, X2, X3)
mark1 > U41^12
U41^12: [2,1]
mark1: [1]
U411(mark(X1), X2, X3) → U411(X1, X2, X3)
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, active(X3)) → U411(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U411(mark(X1), X2, X3) → U411(X1, X2, X3)
[U41^13, mark1]
mark1: [1]
U41^13: [3,2,1]
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
U411(X1, X2, active(X3)) → U411(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U411(X1, X2, active(X3)) → U411(X1, X2, X3)
active1 > U41^11
active1: [1]
U41^11: [1]
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U411(active(X1), X2, X3) → U411(X1, X2, X3)
U411(X1, active(X2), X3) → U411(X1, X2, X3)
[U41^13, active1]
active1: [1]
U41^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U331(active(X)) → U331(X)
U331(mark(X)) → U331(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U331(active(X)) → U331(X)
[U33^11, active1]
active1: [1]
U33^11: [1]
U331(mark(X)) → U331(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U331(mark(X)) → U331(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U321(X1, mark(X2)) → U321(X1, X2)
U321(mark(X1), X2) → U321(X1, X2)
U321(active(X1), X2) → U321(X1, X2)
U321(X1, active(X2)) → U321(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U321(X1, mark(X2)) → U321(X1, X2)
U321(mark(X1), X2) → U321(X1, X2)
[U32^12, mark1]
U32^12: [2,1]
mark1: [1]
U321(active(X1), X2) → U321(X1, X2)
U321(X1, active(X2)) → U321(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U321(active(X1), X2) → U321(X1, X2)
U321(X1, active(X2)) → U321(X1, X2)
[U32^12, active1]
active1: [1]
U32^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U311(X1, mark(X2)) → U311(X1, X2)
U311(mark(X1), X2) → U311(X1, X2)
U311(active(X1), X2) → U311(X1, X2)
U311(X1, active(X2)) → U311(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U311(X1, mark(X2)) → U311(X1, X2)
U311(mark(X1), X2) → U311(X1, X2)
[U31^12, mark1]
U31^12: [2,1]
mark1: [1]
U311(active(X1), X2) → U311(X1, X2)
U311(X1, active(X2)) → U311(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U311(active(X1), X2) → U311(X1, X2)
U311(X1, active(X2)) → U311(X1, X2)
[U31^12, active1]
active1: [1]
U31^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U231(active(X)) → U231(X)
U231(mark(X)) → U231(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U231(active(X)) → U231(X)
[U23^11, active1]
active1: [1]
U23^11: [1]
U231(mark(X)) → U231(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U231(mark(X)) → U231(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U221(X1, mark(X2)) → U221(X1, X2)
U221(mark(X1), X2) → U221(X1, X2)
U221(active(X1), X2) → U221(X1, X2)
U221(X1, active(X2)) → U221(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U221(X1, mark(X2)) → U221(X1, X2)
U221(mark(X1), X2) → U221(X1, X2)
[U22^12, mark1]
U22^12: [2,1]
mark1: [1]
U221(active(X1), X2) → U221(X1, X2)
U221(X1, active(X2)) → U221(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U221(active(X1), X2) → U221(X1, X2)
U221(X1, active(X2)) → U221(X1, X2)
[U22^12, active1]
active1: [1]
U22^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U211(X1, mark(X2)) → U211(X1, X2)
U211(mark(X1), X2) → U211(X1, X2)
U211(active(X1), X2) → U211(X1, X2)
U211(X1, active(X2)) → U211(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U211(X1, mark(X2)) → U211(X1, X2)
U211(mark(X1), X2) → U211(X1, X2)
[U21^12, mark1]
U21^12: [2,1]
mark1: [1]
U211(active(X1), X2) → U211(X1, X2)
U211(X1, active(X2)) → U211(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U211(active(X1), X2) → U211(X1, X2)
U211(X1, active(X2)) → U211(X1, X2)
[U21^12, active1]
active1: [1]
U21^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
TAKE(X1, mark(X2)) → TAKE(X1, X2)
TAKE(mark(X1), X2) → TAKE(X1, X2)
TAKE(active(X1), X2) → TAKE(X1, X2)
TAKE(X1, active(X2)) → TAKE(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
TAKE(X1, mark(X2)) → TAKE(X1, X2)
TAKE(mark(X1), X2) → TAKE(X1, X2)
[TAKE2, mark1]
TAKE2: [2,1]
mark1: [1]
TAKE(active(X1), X2) → TAKE(X1, X2)
TAKE(X1, active(X2)) → TAKE(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
TAKE(active(X1), X2) → TAKE(X1, X2)
TAKE(X1, active(X2)) → TAKE(X1, X2)
[TAKE2, active1]
active1: [1]
TAKE2: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, mark(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, mark(X4)) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, active(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, active(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, active(X4)) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(X1, X2, mark(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, mark(X4)) → U1361(X1, X2, X3, X4)
trivial
mark1: [1]
U136^12: [2,1]
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, active(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, active(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, active(X4)) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(X1, X2, active(X3), X4) → U1361(X1, X2, X3, X4)
U1361(X1, X2, X3, active(X4)) → U1361(X1, X2, X3, X4)
trivial
active1: [1]
mark: []
U136^12: [2,1]
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(X1, active(X2), X3, X4) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(X1, active(X2), X3, X4) → U1361(X1, X2, X3, X4)
active1 > U136^11
active1: [1]
U136^11: [1]
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(X1, mark(X2), X3, X4) → U1361(X1, X2, X3, X4)
trivial
active: []
mark1: [1]
U136^12: [1,2]
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(active(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
[U136^12, active1]
active1: [1]
U136^12: [1,2]
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1361(mark(X1), X2, X3, X4) → U1361(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, mark(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, mark(X4)) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, active(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, active(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, active(X4)) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(X1, X2, mark(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, mark(X4)) → U1351(X1, X2, X3, X4)
trivial
mark1: [1]
U135^12: [2,1]
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, active(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, active(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, active(X4)) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(X1, X2, active(X3), X4) → U1351(X1, X2, X3, X4)
U1351(X1, X2, X3, active(X4)) → U1351(X1, X2, X3, X4)
trivial
active1: [1]
mark: []
U135^12: [2,1]
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(X1, active(X2), X3, X4) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(X1, active(X2), X3, X4) → U1351(X1, X2, X3, X4)
active1 > U135^11
active1: [1]
U135^11: [1]
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(X1, mark(X2), X3, X4) → U1351(X1, X2, X3, X4)
trivial
active: []
mark1: [1]
U135^12: [1,2]
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(active(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
[U135^12, active1]
active1: [1]
U135^12: [1,2]
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1351(mark(X1), X2, X3, X4) → U1351(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, mark(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, mark(X4)) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, active(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, active(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, active(X4)) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(X1, X2, mark(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, mark(X4)) → U1341(X1, X2, X3, X4)
trivial
mark1: [1]
U134^12: [2,1]
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, active(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, active(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, active(X4)) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(X1, X2, active(X3), X4) → U1341(X1, X2, X3, X4)
U1341(X1, X2, X3, active(X4)) → U1341(X1, X2, X3, X4)
trivial
active1: [1]
mark: []
U134^12: [2,1]
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(X1, active(X2), X3, X4) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(X1, active(X2), X3, X4) → U1341(X1, X2, X3, X4)
active1 > U134^11
active1: [1]
U134^11: [1]
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(X1, mark(X2), X3, X4) → U1341(X1, X2, X3, X4)
trivial
active: []
U134^12: [1,2]
mark1: [1]
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(active(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
[U134^12, active1]
active1: [1]
U134^12: [1,2]
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1341(mark(X1), X2, X3, X4) → U1341(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, mark(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, mark(X4)) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, active(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, active(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, active(X4)) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(X1, X2, mark(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, mark(X4)) → U1331(X1, X2, X3, X4)
trivial
U133^12: [2,1]
mark1: [1]
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, active(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, active(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, active(X4)) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(X1, X2, active(X3), X4) → U1331(X1, X2, X3, X4)
U1331(X1, X2, X3, active(X4)) → U1331(X1, X2, X3, X4)
trivial
active1: [1]
U133^12: [2,1]
mark: []
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(X1, active(X2), X3, X4) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(X1, active(X2), X3, X4) → U1331(X1, X2, X3, X4)
active1 > U133^11
active1: [1]
U133^11: [1]
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(X1, mark(X2), X3, X4) → U1331(X1, X2, X3, X4)
trivial
active: []
U133^12: [1,2]
mark1: [1]
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(active(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
[U133^12, active1]
active1: [1]
U133^12: [1,2]
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1331(mark(X1), X2, X3, X4) → U1331(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, mark(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, mark(X4)) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, active(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, active(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, active(X4)) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(X1, X2, mark(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, mark(X4)) → U1321(X1, X2, X3, X4)
trivial
U132^12: [2,1]
mark1: [1]
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, active(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, active(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, active(X4)) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(X1, X2, active(X3), X4) → U1321(X1, X2, X3, X4)
U1321(X1, X2, X3, active(X4)) → U1321(X1, X2, X3, X4)
trivial
active1: [1]
U132^12: [2,1]
mark: []
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(X1, active(X2), X3, X4) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(X1, active(X2), X3, X4) → U1321(X1, X2, X3, X4)
active1 > U132^11
active1: [1]
U132^11: [1]
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(X1, mark(X2), X3, X4) → U1321(X1, X2, X3, X4)
trivial
active: []
U132^12: [1,2]
mark1: [1]
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(active(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
[U132^12, active1]
active1: [1]
U132^12: [1,2]
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1321(mark(X1), X2, X3, X4) → U1321(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, mark(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, mark(X4)) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, active(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, active(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, active(X4)) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(X1, X2, mark(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, mark(X4)) → U1311(X1, X2, X3, X4)
trivial
U131^12: [2,1]
mark1: [1]
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, active(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, active(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, active(X4)) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(X1, X2, active(X3), X4) → U1311(X1, X2, X3, X4)
U1311(X1, X2, X3, active(X4)) → U1311(X1, X2, X3, X4)
trivial
active1: [1]
U131^12: [2,1]
mark: []
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(X1, active(X2), X3, X4) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(X1, active(X2), X3, X4) → U1311(X1, X2, X3, X4)
active1 > U131^11
active1: [1]
U131^11: [1]
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(X1, mark(X2), X3, X4) → U1311(X1, X2, X3, X4)
trivial
active: []
U131^12: [1,2]
mark1: [1]
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(active(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
[U131^12, active1]
active1: [1]
U131^12: [1,2]
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1311(mark(X1), X2, X3, X4) → U1311(X1, X2, X3, X4)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1221(active(X)) → U1221(X)
U1221(mark(X)) → U1221(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1221(active(X)) → U1221(X)
[U122^11, active1]
active1: [1]
U122^11: [1]
U1221(mark(X)) → U1221(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1221(mark(X)) → U1221(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1211(X1, mark(X2)) → U1211(X1, X2)
U1211(mark(X1), X2) → U1211(X1, X2)
U1211(active(X1), X2) → U1211(X1, X2)
U1211(X1, active(X2)) → U1211(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1211(X1, mark(X2)) → U1211(X1, X2)
U1211(mark(X1), X2) → U1211(X1, X2)
[U121^12, mark1]
mark1: [1]
U121^12: [2,1]
U1211(active(X1), X2) → U1211(X1, X2)
U1211(X1, active(X2)) → U1211(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1211(active(X1), X2) → U1211(X1, X2)
U1211(X1, active(X2)) → U1211(X1, X2)
[U121^12, active1]
active1: [1]
U121^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ISNATLIST(active(X)) → ISNATLIST(X)
ISNATLIST(mark(X)) → ISNATLIST(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATLIST(active(X)) → ISNATLIST(X)
[ISNATLIST1, active1]
active1: [1]
ISNATLIST1: [1]
ISNATLIST(mark(X)) → ISNATLIST(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATLIST(mark(X)) → ISNATLIST(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U131(active(X)) → U131(X)
U131(mark(X)) → U131(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U131(active(X)) → U131(X)
[U13^11, active1]
active1: [1]
U13^11: [1]
U131(mark(X)) → U131(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U131(mark(X)) → U131(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
LENGTH(active(X)) → LENGTH(X)
LENGTH(mark(X)) → LENGTH(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LENGTH(active(X)) → LENGTH(X)
[LENGTH1, active1]
active1: [1]
LENGTH1: [1]
LENGTH(mark(X)) → LENGTH(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LENGTH(mark(X)) → LENGTH(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
S(active(X)) → S(X)
S(mark(X)) → S(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
S(active(X)) → S(X)
[S1, active1]
active1: [1]
S1: [1]
S(mark(X)) → S(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
S(mark(X)) → S(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1141(X1, mark(X2)) → U1141(X1, X2)
U1141(mark(X1), X2) → U1141(X1, X2)
U1141(active(X1), X2) → U1141(X1, X2)
U1141(X1, active(X2)) → U1141(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1141(X1, mark(X2)) → U1141(X1, X2)
U1141(mark(X1), X2) → U1141(X1, X2)
[U114^12, mark1]
mark1: [1]
U114^12: [2,1]
U1141(active(X1), X2) → U1141(X1, X2)
U1141(X1, active(X2)) → U1141(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1141(active(X1), X2) → U1141(X1, X2)
U1141(X1, active(X2)) → U1141(X1, X2)
[U114^12, active1]
active1: [1]
U114^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1131(X1, mark(X2), X3) → U1131(X1, X2, X3)
U1131(mark(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, X2, mark(X3)) → U1131(X1, X2, X3)
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, active(X3)) → U1131(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1131(X1, mark(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, mark(X3)) → U1131(X1, X2, X3)
mark1 > U113^12
U113^12: [2,1]
mark1: [1]
U1131(mark(X1), X2, X3) → U1131(X1, X2, X3)
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, active(X3)) → U1131(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1131(mark(X1), X2, X3) → U1131(X1, X2, X3)
[U113^13, mark1]
U113^13: [3,2,1]
mark1: [1]
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
U1131(X1, X2, active(X3)) → U1131(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1131(X1, X2, active(X3)) → U1131(X1, X2, X3)
active1 > U113^11
active1: [1]
U113^11: [1]
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1131(active(X1), X2, X3) → U1131(X1, X2, X3)
U1131(X1, active(X2), X3) → U1131(X1, X2, X3)
[U113^13, active1]
active1: [1]
U113^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1121(X1, mark(X2), X3) → U1121(X1, X2, X3)
U1121(mark(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, X2, mark(X3)) → U1121(X1, X2, X3)
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, active(X3)) → U1121(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1121(X1, mark(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, mark(X3)) → U1121(X1, X2, X3)
mark1 > U112^12
mark1: [1]
U112^12: [2,1]
U1121(mark(X1), X2, X3) → U1121(X1, X2, X3)
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, active(X3)) → U1121(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1121(mark(X1), X2, X3) → U1121(X1, X2, X3)
[U112^13, mark1]
mark1: [1]
U112^13: [3,2,1]
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
U1121(X1, X2, active(X3)) → U1121(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1121(X1, X2, active(X3)) → U1121(X1, X2, X3)
active1 > U112^11
active1: [1]
U112^11: [1]
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1121(active(X1), X2, X3) → U1121(X1, X2, X3)
U1121(X1, active(X2), X3) → U1121(X1, X2, X3)
[U112^13, active1]
active1: [1]
U112^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1111(X1, mark(X2), X3) → U1111(X1, X2, X3)
U1111(mark(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, X2, mark(X3)) → U1111(X1, X2, X3)
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, active(X3)) → U1111(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1111(X1, mark(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, mark(X3)) → U1111(X1, X2, X3)
mark1 > U111^12
mark1: [1]
U111^12: [2,1]
U1111(mark(X1), X2, X3) → U1111(X1, X2, X3)
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, active(X3)) → U1111(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1111(mark(X1), X2, X3) → U1111(X1, X2, X3)
[U111^13, mark1]
U111^13: [3,2,1]
mark1: [1]
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
U1111(X1, X2, active(X3)) → U1111(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1111(X1, X2, active(X3)) → U1111(X1, X2, X3)
active1 > U111^11
active1: [1]
U111^11: [1]
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1111(active(X1), X2, X3) → U1111(X1, X2, X3)
U1111(X1, active(X2), X3) → U1111(X1, X2, X3)
[U111^13, active1]
active1: [1]
U111^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U121(X1, mark(X2)) → U121(X1, X2)
U121(mark(X1), X2) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U121(X1, mark(X2)) → U121(X1, X2)
U121(mark(X1), X2) → U121(X1, X2)
[U12^12, mark1]
U12^12: [2,1]
mark1: [1]
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
[U12^12, active1]
active1: [1]
U12^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U111(X1, mark(X2)) → U111(X1, X2)
U111(mark(X1), X2) → U111(X1, X2)
U111(active(X1), X2) → U111(X1, X2)
U111(X1, active(X2)) → U111(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U111(X1, mark(X2)) → U111(X1, X2)
U111(mark(X1), X2) → U111(X1, X2)
[U11^12, mark1]
U11^12: [2,1]
mark1: [1]
U111(active(X1), X2) → U111(X1, X2)
U111(X1, active(X2)) → U111(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U111(active(X1), X2) → U111(X1, X2)
U111(X1, active(X2)) → U111(X1, X2)
[U11^12, active1]
active1: [1]
U11^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ISNATILIST(active(X)) → ISNATILIST(X)
ISNATILIST(mark(X)) → ISNATILIST(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATILIST(active(X)) → ISNATILIST(X)
[ISNATILIST1, active1]
active1: [1]
ISNATILIST1: [1]
ISNATILIST(mark(X)) → ISNATILIST(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATILIST(mark(X)) → ISNATILIST(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1061(active(X)) → U1061(X)
U1061(mark(X)) → U1061(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1061(active(X)) → U1061(X)
[U106^11, active1]
active1: [1]
U106^11: [1]
U1061(mark(X)) → U1061(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1061(mark(X)) → U1061(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ISNAT(active(X)) → ISNAT(X)
ISNAT(mark(X)) → ISNAT(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNAT(active(X)) → ISNAT(X)
[ISNAT1, active1]
active1: [1]
ISNAT1: [1]
ISNAT(mark(X)) → ISNAT(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNAT(mark(X)) → ISNAT(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1051(X1, mark(X2)) → U1051(X1, X2)
U1051(mark(X1), X2) → U1051(X1, X2)
U1051(active(X1), X2) → U1051(X1, X2)
U1051(X1, active(X2)) → U1051(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1051(X1, mark(X2)) → U1051(X1, X2)
U1051(mark(X1), X2) → U1051(X1, X2)
[U105^12, mark1]
U105^12: [2,1]
mark1: [1]
U1051(active(X1), X2) → U1051(X1, X2)
U1051(X1, active(X2)) → U1051(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1051(active(X1), X2) → U1051(X1, X2)
U1051(X1, active(X2)) → U1051(X1, X2)
[U105^12, active1]
active1: [1]
U105^12: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1041(X1, mark(X2), X3) → U1041(X1, X2, X3)
U1041(mark(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, X2, mark(X3)) → U1041(X1, X2, X3)
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, active(X3)) → U1041(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1041(X1, mark(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, mark(X3)) → U1041(X1, X2, X3)
mark1 > U104^12
U104^12: [2,1]
mark1: [1]
U1041(mark(X1), X2, X3) → U1041(X1, X2, X3)
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, active(X3)) → U1041(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1041(mark(X1), X2, X3) → U1041(X1, X2, X3)
[U104^13, mark1]
U104^13: [3,2,1]
mark1: [1]
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
U1041(X1, X2, active(X3)) → U1041(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1041(X1, X2, active(X3)) → U1041(X1, X2, X3)
active1 > U104^11
active1: [1]
U104^11: [1]
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1041(active(X1), X2, X3) → U1041(X1, X2, X3)
U1041(X1, active(X2), X3) → U1041(X1, X2, X3)
[U104^13, active1]
active1: [1]
U104^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ISNATILISTKIND(active(X)) → ISNATILISTKIND(X)
ISNATILISTKIND(mark(X)) → ISNATILISTKIND(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATILISTKIND(active(X)) → ISNATILISTKIND(X)
[ISNATILISTKIND1, active1]
active1: [1]
ISNATILISTKIND1: [1]
ISNATILISTKIND(mark(X)) → ISNATILISTKIND(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATILISTKIND(mark(X)) → ISNATILISTKIND(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1031(X1, mark(X2), X3) → U1031(X1, X2, X3)
U1031(mark(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, X2, mark(X3)) → U1031(X1, X2, X3)
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, active(X3)) → U1031(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1031(X1, mark(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, mark(X3)) → U1031(X1, X2, X3)
mark1 > U103^12
mark1: [1]
U103^12: [2,1]
U1031(mark(X1), X2, X3) → U1031(X1, X2, X3)
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, active(X3)) → U1031(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1031(mark(X1), X2, X3) → U1031(X1, X2, X3)
[U103^13, mark1]
mark1: [1]
U103^13: [3,2,1]
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
U1031(X1, X2, active(X3)) → U1031(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1031(X1, X2, active(X3)) → U1031(X1, X2, X3)
active1 > U103^11
active1: [1]
U103^11: [1]
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1031(active(X1), X2, X3) → U1031(X1, X2, X3)
U1031(X1, active(X2), X3) → U1031(X1, X2, X3)
[U103^13, active1]
active1: [1]
U103^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
ISNATKIND(active(X)) → ISNATKIND(X)
ISNATKIND(mark(X)) → ISNATKIND(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATKIND(active(X)) → ISNATKIND(X)
[ISNATKIND1, active1]
active1: [1]
ISNATKIND1: [1]
ISNATKIND(mark(X)) → ISNATKIND(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ISNATKIND(mark(X)) → ISNATKIND(X)
trivial
mark1: [1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1021(X1, mark(X2), X3) → U1021(X1, X2, X3)
U1021(mark(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, X2, mark(X3)) → U1021(X1, X2, X3)
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, active(X3)) → U1021(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1021(X1, mark(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, mark(X3)) → U1021(X1, X2, X3)
mark1 > U102^12
U102^12: [2,1]
mark1: [1]
U1021(mark(X1), X2, X3) → U1021(X1, X2, X3)
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, active(X3)) → U1021(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1021(mark(X1), X2, X3) → U1021(X1, X2, X3)
[U102^13, mark1]
U102^13: [3,2,1]
mark1: [1]
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
U1021(X1, X2, active(X3)) → U1021(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1021(X1, X2, active(X3)) → U1021(X1, X2, X3)
active1 > U102^11
active1: [1]
U102^11: [1]
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1021(active(X1), X2, X3) → U1021(X1, X2, X3)
U1021(X1, active(X2), X3) → U1021(X1, X2, X3)
[U102^13, active1]
active1: [1]
U102^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
U1011(X1, mark(X2), X3) → U1011(X1, X2, X3)
U1011(mark(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, X2, mark(X3)) → U1011(X1, X2, X3)
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, active(X3)) → U1011(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1011(X1, mark(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, mark(X3)) → U1011(X1, X2, X3)
mark1 > U101^12
mark1: [1]
U101^12: [2,1]
U1011(mark(X1), X2, X3) → U1011(X1, X2, X3)
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, active(X3)) → U1011(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1011(mark(X1), X2, X3) → U1011(X1, X2, X3)
[U101^13, mark1]
mark1: [1]
U101^13: [3,2,1]
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
U1011(X1, X2, active(X3)) → U1011(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1011(X1, X2, active(X3)) → U1011(X1, X2, X3)
active1 > U101^11
active1: [1]
U101^11: [1]
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U1011(active(X1), X2, X3) → U1011(X1, X2, X3)
U1011(X1, active(X2), X3) → U1011(X1, X2, X3)
[U101^13, active1]
active1: [1]
U101^13: [3,2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
CONS(X1, mark(X2)) → CONS(X1, X2)
CONS(mark(X1), X2) → CONS(X1, X2)
CONS(active(X1), X2) → CONS(X1, X2)
CONS(X1, active(X2)) → CONS(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
CONS(X1, mark(X2)) → CONS(X1, X2)
CONS(mark(X1), X2) → CONS(X1, X2)
[CONS2, mark1]
CONS2: [2,1]
mark1: [1]
CONS(active(X1), X2) → CONS(X1, X2)
CONS(X1, active(X2)) → CONS(X1, X2)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
CONS(active(X1), X2) → CONS(X1, X2)
CONS(X1, active(X2)) → CONS(X1, X2)
[CONS2, active1]
active1: [1]
CONS2: [2,1]
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
MARK(cons(X1, X2)) → ACTIVE(cons(mark(X1), X2))
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
MARK(U106(X)) → ACTIVE(U106(mark(X)))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
MARK(s(X)) → ACTIVE(s(mark(X)))
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
MARK(U13(X)) → ACTIVE(U13(mark(X)))
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
MARK(U122(X)) → ACTIVE(U122(mark(X)))
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
MARK(U23(X)) → ACTIVE(U23(mark(X)))
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
MARK(U33(X)) → ACTIVE(U33(mark(X)))
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
MARK(U46(X)) → ACTIVE(U46(mark(X)))
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
MARK(U52(X)) → ACTIVE(U52(mark(X)))
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
MARK(U62(X)) → ACTIVE(U62(mark(X)))
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
MARK(U71(X)) → ACTIVE(U71(mark(X)))
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(cons(X1, X2)) → ACTIVE(cons(mark(X1), X2))
0 > [MARK, U101, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, U106, isNatIList, U11, U12, U111, U112, U113, U114, s, length, U13, isNatList, U121, U122, U131, U132, U133, U134, U135, U136, take, U21, U22, U23, U31, U32, U33, U41, U42, U43, U44, U45, U46, U51, U52, U61, U62, U91, U92, U93, U94, U95, U96, U71, U81] > cons > mark > active
0 > [MARK, U101, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, U106, isNatIList, U11, U12, U111, U112, U113, U114, s, length, U13, isNatList, U121, U122, U131, U132, U133, U134, U135, U136, take, U21, U22, U23, U31, U32, U33, U41, U42, U43, U44, U45, U46, U51, U52, U61, U62, U91, U92, U93, U94, U95, U96, U71, U81] > tt > mark > active
nil > tt > mark > active
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
U33: []
isNatIList: []
U136: []
tt: []
cons: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
active: []
U51: []
MARK: []
U104: []
U45: []
mark: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U135: []
zeros: []
U94: []
U43: []
U23: []
U95: []
U13: []
U46: []
U21: []
U106: []
U62: []
U32: []
isNatList: []
U91: []
U52: []
U12: []
U93: []
U132: []
s: []
U131: []
U71: []
0: []
take: []
U113: []
U103: []
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U33(active(X)) → U33(X)
U33(mark(X)) → U33(X)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U52(active(X)) → U52(X)
U52(mark(X)) → U52(X)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U62(active(X)) → U62(X)
U62(mark(X)) → U62(X)
U71(active(X)) → U71(X)
U71(mark(X)) → U71(X)
U81(active(X)) → U81(X)
U81(mark(X)) → U81(X)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
cons(X1, active(X2)) → cons(X1, X2)
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U106(active(X)) → U106(X)
U106(mark(X)) → U106(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
s(active(X)) → s(X)
s(mark(X)) → s(X)
length(active(X)) → length(X)
length(mark(X)) → length(X)
U13(active(X)) → U13(X)
U13(mark(X)) → U13(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U122(active(X)) → U122(X)
U122(mark(X)) → U122(X)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
MARK(U106(X)) → ACTIVE(U106(mark(X)))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
MARK(s(X)) → ACTIVE(s(mark(X)))
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
MARK(U13(X)) → ACTIVE(U13(mark(X)))
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
MARK(U122(X)) → ACTIVE(U122(mark(X)))
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
MARK(U23(X)) → ACTIVE(U23(mark(X)))
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
MARK(U33(X)) → ACTIVE(U33(mark(X)))
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
MARK(U46(X)) → ACTIVE(U46(mark(X)))
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
MARK(U52(X)) → ACTIVE(U52(mark(X)))
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
MARK(U62(X)) → ACTIVE(U62(mark(X)))
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
MARK(U71(X)) → ACTIVE(U71(mark(X)))
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(U122(X)) → ACTIVE(U122(mark(X)))
[0, nil] > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, U106, isNatIList, U11, U12, U111, U112, U113, U114, s, length, U13, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U23, U31, U32, U33, U41, U42, U43, U44, U45, U46, U51, U52, U61, U62, U91, U92, U93, U94, U95, U96, U71, U81] > cons2 > active1 > mark1
[0, nil] > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, U106, isNatIList, U11, U12, U111, U112, U113, U114, s, length, U13, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U23, U31, U32, U33, U41, U42, U43, U44, U45, U46, U51, U52, U61, U62, U91, U92, U93, U94, U95, U96, U71, U81] > U122 > active1 > mark1
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
mark1: [1]
U33: []
isNatIList: []
U136: []
active1: [1]
tt: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
U51: []
MARK: []
U104: []
U45: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U135: []
zeros: []
U94: []
U43: []
U23: []
U95: []
U13: []
U46: []
U21: []
U106: []
U62: []
U32: []
isNatList: []
U91: []
U52: []
U12: []
U93: []
U132: []
s: []
U131: []
U71: []
0: []
take: []
U113: []
U103: []
cons2: [2,1]
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U33(active(X)) → U33(X)
U33(mark(X)) → U33(X)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U52(active(X)) → U52(X)
U52(mark(X)) → U52(X)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U62(active(X)) → U62(X)
U62(mark(X)) → U62(X)
U71(active(X)) → U71(X)
U71(mark(X)) → U71(X)
U81(active(X)) → U81(X)
U81(mark(X)) → U81(X)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U106(active(X)) → U106(X)
U106(mark(X)) → U106(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
s(active(X)) → s(X)
s(mark(X)) → s(X)
length(active(X)) → length(X)
length(mark(X)) → length(X)
U13(active(X)) → U13(X)
U13(mark(X)) → U13(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U122(active(X)) → U122(X)
U122(mark(X)) → U122(X)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
MARK(U106(X)) → ACTIVE(U106(mark(X)))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
MARK(s(X)) → ACTIVE(s(mark(X)))
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
MARK(U13(X)) → ACTIVE(U13(mark(X)))
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
MARK(U23(X)) → ACTIVE(U23(mark(X)))
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
MARK(U33(X)) → ACTIVE(U33(mark(X)))
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
MARK(U46(X)) → ACTIVE(U46(mark(X)))
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
MARK(U52(X)) → ACTIVE(U52(mark(X)))
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
MARK(U62(X)) → ACTIVE(U62(mark(X)))
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
MARK(U71(X)) → ACTIVE(U71(mark(X)))
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(U106(X)) → ACTIVE(U106(mark(X)))
MARK(s(X)) → ACTIVE(s(mark(X)))
MARK(U13(X)) → ACTIVE(U13(mark(X)))
MARK(U23(X)) → ACTIVE(U23(mark(X)))
MARK(U46(X)) → ACTIVE(U46(mark(X)))
MARK(U52(X)) → ACTIVE(U52(mark(X)))
MARK(U62(X)) → ACTIVE(U62(mark(X)))
MARK(U71(X)) → ACTIVE(U71(mark(X)))
cons1 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U33, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U106 > [0, mark, U52, U71] > active > [tt, U13] > [U122, U46]
cons1 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U33, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > s > [0, mark, U52, U71] > active > [tt, U13] > [U122, U46]
cons1 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U33, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U23 > [0, mark, U52, U71] > active > [tt, U13] > [U122, U46]
cons1 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U33, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U62 > [0, mark, U52, U71] > active > [tt, U13] > [U122, U46]
nil > [0, mark, U52, U71] > active > [tt, U13] > [U122, U46]
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
U33: []
isNatIList: []
U136: []
tt: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
active: []
U51: []
MARK: []
cons1: [1]
U104: []
U45: []
mark: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U135: []
zeros: []
U94: []
U43: []
U23: []
U95: []
U13: []
U46: []
U21: []
U106: []
U62: []
U32: []
isNatList: []
U91: []
U52: []
U12: []
U93: []
U132: []
s: []
U131: []
U71: []
0: []
take: []
U113: []
U103: []
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U33(active(X)) → U33(X)
U33(mark(X)) → U33(X)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U52(active(X)) → U52(X)
U52(mark(X)) → U52(X)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U62(active(X)) → U62(X)
U62(mark(X)) → U62(X)
U71(active(X)) → U71(X)
U71(mark(X)) → U71(X)
U81(active(X)) → U81(X)
U81(mark(X)) → U81(X)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U106(active(X)) → U106(X)
U106(mark(X)) → U106(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
s(active(X)) → s(X)
s(mark(X)) → s(X)
length(active(X)) → length(X)
length(mark(X)) → length(X)
U13(active(X)) → U13(X)
U13(mark(X)) → U13(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
MARK(U33(X)) → ACTIVE(U33(mark(X)))
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(U33(X)) → ACTIVE(U33(mark(X)))
0 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
0 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
0 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
0 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
0 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
0 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
0 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
0 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U13 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U13 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U13 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U13 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U13 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U13 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U13 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U13 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U62 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U62 > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U62 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U62 > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U62 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U62 > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U62 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
U62 > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
nil > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
nil > [tt, U52] > [mark, s1, active1] > cons2 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
nil > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
nil > [tt, U52] > [mark, s1, active1] > U106 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
nil > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
nil > [tt, U52] > [mark, s1, active1] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
nil > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U231 > U122
nil > [tt, U52] > [mark, s1, active1] > U71 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95, U96, U81] > U33 > U122
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
U33: []
isNatIList: []
U231: [1]
U136: []
active1: [1]
tt: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
U51: []
MARK: []
U104: []
U45: []
mark: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U135: []
zeros: []
U94: []
s1: [1]
U43: []
U95: []
U13: []
U46: []
U21: []
U106: []
U62: []
U32: []
isNatList: []
U91: []
U52: []
U12: []
U93: []
U132: []
U131: []
U71: []
0: []
take: []
U113: []
U103: []
cons2: [2,1]
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U33(active(X)) → U33(X)
U33(mark(X)) → U33(X)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U81(active(X)) → U81(X)
U81(mark(X)) → U81(X)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
length(active(X)) → length(X)
length(mark(X)) → length(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → ACTIVE(U81(mark(X)))
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(U81(X)) → ACTIVE(U81(mark(X)))
cons2 > [U13, active1] > s1 > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
cons2 > [U13, active1] > U122 > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
cons2 > [U13, active1] > nil > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
U62 > [U13, active1] > s1 > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
U62 > [U13, active1] > U122 > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
U62 > [U13, active1] > nil > [U101, tt, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U52, U61, U91, U92, U93, U94, U95, U96, U71] > 0 > [mark, U23, U33, U46, U81]
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
U33: []
isNatIList: []
U136: []
active1: [1]
tt: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
U51: []
MARK: []
U104: []
U45: []
mark: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U135: []
zeros: []
U94: []
s1: [1]
U43: []
U23: []
U95: []
U13: []
U46: []
U21: []
U62: []
U32: []
isNatList: []
U91: []
U52: []
U12: []
U93: []
U132: []
U131: []
U71: []
0: []
take: []
U113: []
U103: []
cons2: [2,1]
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U81(active(X)) → U81(X)
U81(mark(X)) → U81(X)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
length(active(X)) → length(X)
length(mark(X)) → length(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → ACTIVE(U96(mark(X)))
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MARK(U96(X)) → ACTIVE(U96(mark(X)))
[tt, 0] > U23 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95] > [mark, U1061, U122, U33, U521, U621, U96, U711, active1]
[tt, 0] > U46 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95] > [mark, U1061, U122, U33, U521, U621, U96, U711, active1]
[tt, 0] > nil > [mark, U1061, U122, U33, U521, U621, U96, U711, active1]
s > U81 > [U101, MARK, U102, isNatKind, zeros, U103, isNatIListKind, U104, U105, isNat, isNatIList, U11, U12, U111, U112, U113, U114, length, isNatList, U121, U131, U132, U133, U134, U135, U136, take, U21, U22, U31, U32, U41, U42, U43, U44, U45, U51, U61, U91, U92, U93, U94, U95] > [mark, U1061, U122, U33, U521, U621, U96, U711, active1]
U134: []
U22: []
U92: []
U31: []
U42: []
U11: []
U33: []
isNatIList: []
U136: []
active1: [1]
U1061: [1]
tt: []
U121: []
U41: []
isNatKind: []
U81: []
nil: []
U122: []
U51: []
MARK: []
U104: []
U621: [1]
U45: []
mark: []
U133: []
U44: []
U114: []
U112: []
U111: []
length: []
U96: []
isNat: []
U61: []
U521: [1]
U135: []
zeros: []
U94: []
U43: []
U23: []
U711: [1]
U95: []
U46: []
U21: []
U32: []
isNatList: []
U91: []
U12: []
U93: []
U132: []
s: []
U131: []
0: []
take: []
U113: []
U103: []
U102: []
U101: []
U105: []
isNatIListKind: []
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U32(X1, mark(X2)) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(mark(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U45(mark(X1), X2) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(mark(X1), X2) → U51(X1, X2)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U96(active(X)) → U96(X)
U96(mark(X)) → U96(X)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
isNatIListKind(active(X)) → isNatIListKind(X)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNat(active(X)) → isNat(X)
isNat(mark(X)) → isNat(X)
U105(mark(X1), X2) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
isNatKind(active(X)) → isNatKind(X)
isNatKind(mark(X)) → isNatKind(X)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
length(active(X)) → length(X)
length(mark(X)) → length(X)
isNatList(active(X)) → isNatList(X)
isNatList(mark(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
ACTIVE(U101(tt, V1, V2)) → MARK(U102(isNatKind(V1), V1, V2))
MARK(cons(X1, X2)) → MARK(X1)
MARK(zeros) → ACTIVE(zeros)
ACTIVE(zeros) → MARK(cons(0, zeros))
MARK(U101(X1, X2, X3)) → ACTIVE(U101(mark(X1), X2, X3))
ACTIVE(U102(tt, V1, V2)) → MARK(U103(isNatIListKind(V2), V1, V2))
MARK(U101(X1, X2, X3)) → MARK(X1)
MARK(U102(X1, X2, X3)) → ACTIVE(U102(mark(X1), X2, X3))
ACTIVE(U103(tt, V1, V2)) → MARK(U104(isNatIListKind(V2), V1, V2))
MARK(U102(X1, X2, X3)) → MARK(X1)
MARK(isNatKind(X)) → ACTIVE(isNatKind(X))
ACTIVE(U104(tt, V1, V2)) → MARK(U105(isNat(V1), V2))
MARK(U103(X1, X2, X3)) → ACTIVE(U103(mark(X1), X2, X3))
ACTIVE(U105(tt, V2)) → MARK(U106(isNatIList(V2)))
MARK(U103(X1, X2, X3)) → MARK(X1)
MARK(isNatIListKind(X)) → ACTIVE(isNatIListKind(X))
ACTIVE(U11(tt, V1)) → MARK(U12(isNatIListKind(V1), V1))
MARK(U104(X1, X2, X3)) → ACTIVE(U104(mark(X1), X2, X3))
ACTIVE(U111(tt, L, N)) → MARK(U112(isNatIListKind(L), L, N))
MARK(U104(X1, X2, X3)) → MARK(X1)
MARK(U105(X1, X2)) → ACTIVE(U105(mark(X1), X2))
ACTIVE(U112(tt, L, N)) → MARK(U113(isNat(N), L, N))
MARK(U105(X1, X2)) → MARK(X1)
MARK(isNat(X)) → ACTIVE(isNat(X))
ACTIVE(U113(tt, L, N)) → MARK(U114(isNatKind(N), L))
ACTIVE(U114(tt, L)) → MARK(s(length(L)))
MARK(U106(X)) → MARK(X)
MARK(isNatIList(X)) → ACTIVE(isNatIList(X))
ACTIVE(U12(tt, V1)) → MARK(U13(isNatList(V1)))
MARK(U11(X1, X2)) → ACTIVE(U11(mark(X1), X2))
ACTIVE(U121(tt, IL)) → MARK(U122(isNatIListKind(IL)))
MARK(U11(X1, X2)) → MARK(X1)
MARK(U12(X1, X2)) → ACTIVE(U12(mark(X1), X2))
ACTIVE(U131(tt, IL, M, N)) → MARK(U132(isNatIListKind(IL), IL, M, N))
MARK(U12(X1, X2)) → MARK(X1)
MARK(U111(X1, X2, X3)) → ACTIVE(U111(mark(X1), X2, X3))
ACTIVE(U132(tt, IL, M, N)) → MARK(U133(isNat(M), IL, M, N))
MARK(U111(X1, X2, X3)) → MARK(X1)
MARK(U112(X1, X2, X3)) → ACTIVE(U112(mark(X1), X2, X3))
ACTIVE(U133(tt, IL, M, N)) → MARK(U134(isNatKind(M), IL, M, N))
MARK(U112(X1, X2, X3)) → MARK(X1)
MARK(U113(X1, X2, X3)) → ACTIVE(U113(mark(X1), X2, X3))
ACTIVE(U134(tt, IL, M, N)) → MARK(U135(isNat(N), IL, M, N))
MARK(U113(X1, X2, X3)) → MARK(X1)
MARK(U114(X1, X2)) → ACTIVE(U114(mark(X1), X2))
ACTIVE(U135(tt, IL, M, N)) → MARK(U136(isNatKind(N), IL, M, N))
MARK(U114(X1, X2)) → MARK(X1)
ACTIVE(U136(tt, IL, M, N)) → MARK(cons(N, take(M, IL)))
MARK(s(X)) → MARK(X)
MARK(length(X)) → ACTIVE(length(mark(X)))
ACTIVE(U21(tt, V1)) → MARK(U22(isNatKind(V1), V1))
MARK(length(X)) → MARK(X)
ACTIVE(U22(tt, V1)) → MARK(U23(isNat(V1)))
MARK(U13(X)) → MARK(X)
MARK(isNatList(X)) → ACTIVE(isNatList(X))
ACTIVE(U31(tt, V)) → MARK(U32(isNatIListKind(V), V))
MARK(U121(X1, X2)) → ACTIVE(U121(mark(X1), X2))
ACTIVE(U32(tt, V)) → MARK(U33(isNatList(V)))
MARK(U121(X1, X2)) → MARK(X1)
ACTIVE(U41(tt, V1, V2)) → MARK(U42(isNatKind(V1), V1, V2))
MARK(U122(X)) → MARK(X)
MARK(U131(X1, X2, X3, X4)) → ACTIVE(U131(mark(X1), X2, X3, X4))
ACTIVE(U42(tt, V1, V2)) → MARK(U43(isNatIListKind(V2), V1, V2))
MARK(U131(X1, X2, X3, X4)) → MARK(X1)
MARK(U132(X1, X2, X3, X4)) → ACTIVE(U132(mark(X1), X2, X3, X4))
ACTIVE(U43(tt, V1, V2)) → MARK(U44(isNatIListKind(V2), V1, V2))
MARK(U132(X1, X2, X3, X4)) → MARK(X1)
MARK(U133(X1, X2, X3, X4)) → ACTIVE(U133(mark(X1), X2, X3, X4))
ACTIVE(U44(tt, V1, V2)) → MARK(U45(isNat(V1), V2))
MARK(U133(X1, X2, X3, X4)) → MARK(X1)
MARK(U134(X1, X2, X3, X4)) → ACTIVE(U134(mark(X1), X2, X3, X4))
ACTIVE(U45(tt, V2)) → MARK(U46(isNatIList(V2)))
MARK(U134(X1, X2, X3, X4)) → MARK(X1)
MARK(U135(X1, X2, X3, X4)) → ACTIVE(U135(mark(X1), X2, X3, X4))
ACTIVE(U51(tt, V2)) → MARK(U52(isNatIListKind(V2)))
MARK(U135(X1, X2, X3, X4)) → MARK(X1)
MARK(U136(X1, X2, X3, X4)) → ACTIVE(U136(mark(X1), X2, X3, X4))
ACTIVE(U61(tt, V2)) → MARK(U62(isNatIListKind(V2)))
MARK(U136(X1, X2, X3, X4)) → MARK(X1)
MARK(take(X1, X2)) → ACTIVE(take(mark(X1), mark(X2)))
ACTIVE(U91(tt, V1, V2)) → MARK(U92(isNatKind(V1), V1, V2))
MARK(take(X1, X2)) → MARK(X1)
MARK(take(X1, X2)) → MARK(X2)
MARK(U21(X1, X2)) → ACTIVE(U21(mark(X1), X2))
ACTIVE(U92(tt, V1, V2)) → MARK(U93(isNatIListKind(V2), V1, V2))
MARK(U21(X1, X2)) → MARK(X1)
MARK(U22(X1, X2)) → ACTIVE(U22(mark(X1), X2))
ACTIVE(U93(tt, V1, V2)) → MARK(U94(isNatIListKind(V2), V1, V2))
MARK(U22(X1, X2)) → MARK(X1)
ACTIVE(U94(tt, V1, V2)) → MARK(U95(isNat(V1), V2))
MARK(U23(X)) → MARK(X)
MARK(U31(X1, X2)) → ACTIVE(U31(mark(X1), X2))
ACTIVE(U95(tt, V2)) → MARK(U96(isNatList(V2)))
MARK(U31(X1, X2)) → MARK(X1)
MARK(U32(X1, X2)) → ACTIVE(U32(mark(X1), X2))
ACTIVE(isNat(length(V1))) → MARK(U11(isNatIListKind(V1), V1))
MARK(U32(X1, X2)) → MARK(X1)
ACTIVE(isNat(s(V1))) → MARK(U21(isNatKind(V1), V1))
MARK(U33(X)) → MARK(X)
MARK(U41(X1, X2, X3)) → ACTIVE(U41(mark(X1), X2, X3))
ACTIVE(isNatIList(V)) → MARK(U31(isNatIListKind(V), V))
MARK(U41(X1, X2, X3)) → MARK(X1)
MARK(U42(X1, X2, X3)) → ACTIVE(U42(mark(X1), X2, X3))
ACTIVE(isNatIList(cons(V1, V2))) → MARK(U41(isNatKind(V1), V1, V2))
MARK(U42(X1, X2, X3)) → MARK(X1)
MARK(U43(X1, X2, X3)) → ACTIVE(U43(mark(X1), X2, X3))
ACTIVE(isNatIListKind(cons(V1, V2))) → MARK(U51(isNatKind(V1), V2))
MARK(U43(X1, X2, X3)) → MARK(X1)
MARK(U44(X1, X2, X3)) → ACTIVE(U44(mark(X1), X2, X3))
ACTIVE(isNatIListKind(take(V1, V2))) → MARK(U61(isNatKind(V1), V2))
MARK(U44(X1, X2, X3)) → MARK(X1)
MARK(U45(X1, X2)) → ACTIVE(U45(mark(X1), X2))
ACTIVE(isNatKind(length(V1))) → MARK(U71(isNatIListKind(V1)))
MARK(U45(X1, X2)) → MARK(X1)
ACTIVE(isNatKind(s(V1))) → MARK(U81(isNatKind(V1)))
MARK(U46(X)) → MARK(X)
MARK(U51(X1, X2)) → ACTIVE(U51(mark(X1), X2))
ACTIVE(isNatList(cons(V1, V2))) → MARK(U91(isNatKind(V1), V1, V2))
MARK(U51(X1, X2)) → MARK(X1)
ACTIVE(isNatList(take(V1, V2))) → MARK(U101(isNatKind(V1), V1, V2))
MARK(U52(X)) → MARK(X)
MARK(U61(X1, X2)) → ACTIVE(U61(mark(X1), X2))
ACTIVE(length(cons(N, L))) → MARK(U111(isNatList(L), L, N))
MARK(U61(X1, X2)) → MARK(X1)
ACTIVE(take(0, IL)) → MARK(U121(isNatIList(IL), IL))
MARK(U62(X)) → MARK(X)
ACTIVE(take(s(M), cons(N, IL))) → MARK(U131(isNatIList(IL), IL, M, N))
MARK(U71(X)) → MARK(X)
MARK(U81(X)) → MARK(X)
MARK(U91(X1, X2, X3)) → ACTIVE(U91(mark(X1), X2, X3))
MARK(U91(X1, X2, X3)) → MARK(X1)
MARK(U92(X1, X2, X3)) → ACTIVE(U92(mark(X1), X2, X3))
MARK(U92(X1, X2, X3)) → MARK(X1)
MARK(U93(X1, X2, X3)) → ACTIVE(U93(mark(X1), X2, X3))
MARK(U93(X1, X2, X3)) → MARK(X1)
MARK(U94(X1, X2, X3)) → ACTIVE(U94(mark(X1), X2, X3))
MARK(U94(X1, X2, X3)) → MARK(X1)
MARK(U95(X1, X2)) → ACTIVE(U95(mark(X1), X2))
MARK(U95(X1, X2)) → MARK(X1)
MARK(U96(X)) → MARK(X)
active(zeros) → mark(cons(0, zeros))
active(U101(tt, V1, V2)) → mark(U102(isNatKind(V1), V1, V2))
active(U102(tt, V1, V2)) → mark(U103(isNatIListKind(V2), V1, V2))
active(U103(tt, V1, V2)) → mark(U104(isNatIListKind(V2), V1, V2))
active(U104(tt, V1, V2)) → mark(U105(isNat(V1), V2))
active(U105(tt, V2)) → mark(U106(isNatIList(V2)))
active(U106(tt)) → mark(tt)
active(U11(tt, V1)) → mark(U12(isNatIListKind(V1), V1))
active(U111(tt, L, N)) → mark(U112(isNatIListKind(L), L, N))
active(U112(tt, L, N)) → mark(U113(isNat(N), L, N))
active(U113(tt, L, N)) → mark(U114(isNatKind(N), L))
active(U114(tt, L)) → mark(s(length(L)))
active(U12(tt, V1)) → mark(U13(isNatList(V1)))
active(U121(tt, IL)) → mark(U122(isNatIListKind(IL)))
active(U122(tt)) → mark(nil)
active(U13(tt)) → mark(tt)
active(U131(tt, IL, M, N)) → mark(U132(isNatIListKind(IL), IL, M, N))
active(U132(tt, IL, M, N)) → mark(U133(isNat(M), IL, M, N))
active(U133(tt, IL, M, N)) → mark(U134(isNatKind(M), IL, M, N))
active(U134(tt, IL, M, N)) → mark(U135(isNat(N), IL, M, N))
active(U135(tt, IL, M, N)) → mark(U136(isNatKind(N), IL, M, N))
active(U136(tt, IL, M, N)) → mark(cons(N, take(M, IL)))
active(U21(tt, V1)) → mark(U22(isNatKind(V1), V1))
active(U22(tt, V1)) → mark(U23(isNat(V1)))
active(U23(tt)) → mark(tt)
active(U31(tt, V)) → mark(U32(isNatIListKind(V), V))
active(U32(tt, V)) → mark(U33(isNatList(V)))
active(U33(tt)) → mark(tt)
active(U41(tt, V1, V2)) → mark(U42(isNatKind(V1), V1, V2))
active(U42(tt, V1, V2)) → mark(U43(isNatIListKind(V2), V1, V2))
active(U43(tt, V1, V2)) → mark(U44(isNatIListKind(V2), V1, V2))
active(U44(tt, V1, V2)) → mark(U45(isNat(V1), V2))
active(U45(tt, V2)) → mark(U46(isNatIList(V2)))
active(U46(tt)) → mark(tt)
active(U51(tt, V2)) → mark(U52(isNatIListKind(V2)))
active(U52(tt)) → mark(tt)
active(U61(tt, V2)) → mark(U62(isNatIListKind(V2)))
active(U62(tt)) → mark(tt)
active(U71(tt)) → mark(tt)
active(U81(tt)) → mark(tt)
active(U91(tt, V1, V2)) → mark(U92(isNatKind(V1), V1, V2))
active(U92(tt, V1, V2)) → mark(U93(isNatIListKind(V2), V1, V2))
active(U93(tt, V1, V2)) → mark(U94(isNatIListKind(V2), V1, V2))
active(U94(tt, V1, V2)) → mark(U95(isNat(V1), V2))
active(U95(tt, V2)) → mark(U96(isNatList(V2)))
active(U96(tt)) → mark(tt)
active(isNat(0)) → mark(tt)
active(isNat(length(V1))) → mark(U11(isNatIListKind(V1), V1))
active(isNat(s(V1))) → mark(U21(isNatKind(V1), V1))
active(isNatIList(V)) → mark(U31(isNatIListKind(V), V))
active(isNatIList(zeros)) → mark(tt)
active(isNatIList(cons(V1, V2))) → mark(U41(isNatKind(V1), V1, V2))
active(isNatIListKind(nil)) → mark(tt)
active(isNatIListKind(zeros)) → mark(tt)
active(isNatIListKind(cons(V1, V2))) → mark(U51(isNatKind(V1), V2))
active(isNatIListKind(take(V1, V2))) → mark(U61(isNatKind(V1), V2))
active(isNatKind(0)) → mark(tt)
active(isNatKind(length(V1))) → mark(U71(isNatIListKind(V1)))
active(isNatKind(s(V1))) → mark(U81(isNatKind(V1)))
active(isNatList(nil)) → mark(tt)
active(isNatList(cons(V1, V2))) → mark(U91(isNatKind(V1), V1, V2))
active(isNatList(take(V1, V2))) → mark(U101(isNatKind(V1), V1, V2))
active(length(nil)) → mark(0)
active(length(cons(N, L))) → mark(U111(isNatList(L), L, N))
active(take(0, IL)) → mark(U121(isNatIList(IL), IL))
active(take(s(M), cons(N, IL))) → mark(U131(isNatIList(IL), IL, M, N))
mark(zeros) → active(zeros)
mark(cons(X1, X2)) → active(cons(mark(X1), X2))
mark(0) → active(0)
mark(U101(X1, X2, X3)) → active(U101(mark(X1), X2, X3))
mark(tt) → active(tt)
mark(U102(X1, X2, X3)) → active(U102(mark(X1), X2, X3))
mark(isNatKind(X)) → active(isNatKind(X))
mark(U103(X1, X2, X3)) → active(U103(mark(X1), X2, X3))
mark(isNatIListKind(X)) → active(isNatIListKind(X))
mark(U104(X1, X2, X3)) → active(U104(mark(X1), X2, X3))
mark(U105(X1, X2)) → active(U105(mark(X1), X2))
mark(isNat(X)) → active(isNat(X))
mark(U106(X)) → active(U106(mark(X)))
mark(isNatIList(X)) → active(isNatIList(X))
mark(U11(X1, X2)) → active(U11(mark(X1), X2))
mark(U12(X1, X2)) → active(U12(mark(X1), X2))
mark(U111(X1, X2, X3)) → active(U111(mark(X1), X2, X3))
mark(U112(X1, X2, X3)) → active(U112(mark(X1), X2, X3))
mark(U113(X1, X2, X3)) → active(U113(mark(X1), X2, X3))
mark(U114(X1, X2)) → active(U114(mark(X1), X2))
mark(s(X)) → active(s(mark(X)))
mark(length(X)) → active(length(mark(X)))
mark(U13(X)) → active(U13(mark(X)))
mark(isNatList(X)) → active(isNatList(X))
mark(U121(X1, X2)) → active(U121(mark(X1), X2))
mark(U122(X)) → active(U122(mark(X)))
mark(nil) → active(nil)
mark(U131(X1, X2, X3, X4)) → active(U131(mark(X1), X2, X3, X4))
mark(U132(X1, X2, X3, X4)) → active(U132(mark(X1), X2, X3, X4))
mark(U133(X1, X2, X3, X4)) → active(U133(mark(X1), X2, X3, X4))
mark(U134(X1, X2, X3, X4)) → active(U134(mark(X1), X2, X3, X4))
mark(U135(X1, X2, X3, X4)) → active(U135(mark(X1), X2, X3, X4))
mark(U136(X1, X2, X3, X4)) → active(U136(mark(X1), X2, X3, X4))
mark(take(X1, X2)) → active(take(mark(X1), mark(X2)))
mark(U21(X1, X2)) → active(U21(mark(X1), X2))
mark(U22(X1, X2)) → active(U22(mark(X1), X2))
mark(U23(X)) → active(U23(mark(X)))
mark(U31(X1, X2)) → active(U31(mark(X1), X2))
mark(U32(X1, X2)) → active(U32(mark(X1), X2))
mark(U33(X)) → active(U33(mark(X)))
mark(U41(X1, X2, X3)) → active(U41(mark(X1), X2, X3))
mark(U42(X1, X2, X3)) → active(U42(mark(X1), X2, X3))
mark(U43(X1, X2, X3)) → active(U43(mark(X1), X2, X3))
mark(U44(X1, X2, X3)) → active(U44(mark(X1), X2, X3))
mark(U45(X1, X2)) → active(U45(mark(X1), X2))
mark(U46(X)) → active(U46(mark(X)))
mark(U51(X1, X2)) → active(U51(mark(X1), X2))
mark(U52(X)) → active(U52(mark(X)))
mark(U61(X1, X2)) → active(U61(mark(X1), X2))
mark(U62(X)) → active(U62(mark(X)))
mark(U71(X)) → active(U71(mark(X)))
mark(U81(X)) → active(U81(mark(X)))
mark(U91(X1, X2, X3)) → active(U91(mark(X1), X2, X3))
mark(U92(X1, X2, X3)) → active(U92(mark(X1), X2, X3))
mark(U93(X1, X2, X3)) → active(U93(mark(X1), X2, X3))
mark(U94(X1, X2, X3)) → active(U94(mark(X1), X2, X3))
mark(U95(X1, X2)) → active(U95(mark(X1), X2))
mark(U96(X)) → active(U96(mark(X)))
cons(mark(X1), X2) → cons(X1, X2)
cons(X1, mark(X2)) → cons(X1, X2)
cons(active(X1), X2) → cons(X1, X2)
cons(X1, active(X2)) → cons(X1, X2)
U101(mark(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, mark(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, mark(X3)) → U101(X1, X2, X3)
U101(active(X1), X2, X3) → U101(X1, X2, X3)
U101(X1, active(X2), X3) → U101(X1, X2, X3)
U101(X1, X2, active(X3)) → U101(X1, X2, X3)
U102(mark(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, mark(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, mark(X3)) → U102(X1, X2, X3)
U102(active(X1), X2, X3) → U102(X1, X2, X3)
U102(X1, active(X2), X3) → U102(X1, X2, X3)
U102(X1, X2, active(X3)) → U102(X1, X2, X3)
isNatKind(mark(X)) → isNatKind(X)
isNatKind(active(X)) → isNatKind(X)
U103(mark(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, mark(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, mark(X3)) → U103(X1, X2, X3)
U103(active(X1), X2, X3) → U103(X1, X2, X3)
U103(X1, active(X2), X3) → U103(X1, X2, X3)
U103(X1, X2, active(X3)) → U103(X1, X2, X3)
isNatIListKind(mark(X)) → isNatIListKind(X)
isNatIListKind(active(X)) → isNatIListKind(X)
U104(mark(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, mark(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, mark(X3)) → U104(X1, X2, X3)
U104(active(X1), X2, X3) → U104(X1, X2, X3)
U104(X1, active(X2), X3) → U104(X1, X2, X3)
U104(X1, X2, active(X3)) → U104(X1, X2, X3)
U105(mark(X1), X2) → U105(X1, X2)
U105(X1, mark(X2)) → U105(X1, X2)
U105(active(X1), X2) → U105(X1, X2)
U105(X1, active(X2)) → U105(X1, X2)
isNat(mark(X)) → isNat(X)
isNat(active(X)) → isNat(X)
U106(mark(X)) → U106(X)
U106(active(X)) → U106(X)
isNatIList(mark(X)) → isNatIList(X)
isNatIList(active(X)) → isNatIList(X)
U11(mark(X1), X2) → U11(X1, X2)
U11(X1, mark(X2)) → U11(X1, X2)
U11(active(X1), X2) → U11(X1, X2)
U11(X1, active(X2)) → U11(X1, X2)
U12(mark(X1), X2) → U12(X1, X2)
U12(X1, mark(X2)) → U12(X1, X2)
U12(active(X1), X2) → U12(X1, X2)
U12(X1, active(X2)) → U12(X1, X2)
U111(mark(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, mark(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, mark(X3)) → U111(X1, X2, X3)
U111(active(X1), X2, X3) → U111(X1, X2, X3)
U111(X1, active(X2), X3) → U111(X1, X2, X3)
U111(X1, X2, active(X3)) → U111(X1, X2, X3)
U112(mark(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, mark(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, mark(X3)) → U112(X1, X2, X3)
U112(active(X1), X2, X3) → U112(X1, X2, X3)
U112(X1, active(X2), X3) → U112(X1, X2, X3)
U112(X1, X2, active(X3)) → U112(X1, X2, X3)
U113(mark(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, mark(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, mark(X3)) → U113(X1, X2, X3)
U113(active(X1), X2, X3) → U113(X1, X2, X3)
U113(X1, active(X2), X3) → U113(X1, X2, X3)
U113(X1, X2, active(X3)) → U113(X1, X2, X3)
U114(mark(X1), X2) → U114(X1, X2)
U114(X1, mark(X2)) → U114(X1, X2)
U114(active(X1), X2) → U114(X1, X2)
U114(X1, active(X2)) → U114(X1, X2)
s(mark(X)) → s(X)
s(active(X)) → s(X)
length(mark(X)) → length(X)
length(active(X)) → length(X)
U13(mark(X)) → U13(X)
U13(active(X)) → U13(X)
isNatList(mark(X)) → isNatList(X)
isNatList(active(X)) → isNatList(X)
U121(mark(X1), X2) → U121(X1, X2)
U121(X1, mark(X2)) → U121(X1, X2)
U121(active(X1), X2) → U121(X1, X2)
U121(X1, active(X2)) → U121(X1, X2)
U122(mark(X)) → U122(X)
U122(active(X)) → U122(X)
U131(mark(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, mark(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, mark(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, mark(X4)) → U131(X1, X2, X3, X4)
U131(active(X1), X2, X3, X4) → U131(X1, X2, X3, X4)
U131(X1, active(X2), X3, X4) → U131(X1, X2, X3, X4)
U131(X1, X2, active(X3), X4) → U131(X1, X2, X3, X4)
U131(X1, X2, X3, active(X4)) → U131(X1, X2, X3, X4)
U132(mark(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, mark(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, mark(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, mark(X4)) → U132(X1, X2, X3, X4)
U132(active(X1), X2, X3, X4) → U132(X1, X2, X3, X4)
U132(X1, active(X2), X3, X4) → U132(X1, X2, X3, X4)
U132(X1, X2, active(X3), X4) → U132(X1, X2, X3, X4)
U132(X1, X2, X3, active(X4)) → U132(X1, X2, X3, X4)
U133(mark(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, mark(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, mark(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, mark(X4)) → U133(X1, X2, X3, X4)
U133(active(X1), X2, X3, X4) → U133(X1, X2, X3, X4)
U133(X1, active(X2), X3, X4) → U133(X1, X2, X3, X4)
U133(X1, X2, active(X3), X4) → U133(X1, X2, X3, X4)
U133(X1, X2, X3, active(X4)) → U133(X1, X2, X3, X4)
U134(mark(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, mark(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, mark(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, mark(X4)) → U134(X1, X2, X3, X4)
U134(active(X1), X2, X3, X4) → U134(X1, X2, X3, X4)
U134(X1, active(X2), X3, X4) → U134(X1, X2, X3, X4)
U134(X1, X2, active(X3), X4) → U134(X1, X2, X3, X4)
U134(X1, X2, X3, active(X4)) → U134(X1, X2, X3, X4)
U135(mark(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, mark(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, mark(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, mark(X4)) → U135(X1, X2, X3, X4)
U135(active(X1), X2, X3, X4) → U135(X1, X2, X3, X4)
U135(X1, active(X2), X3, X4) → U135(X1, X2, X3, X4)
U135(X1, X2, active(X3), X4) → U135(X1, X2, X3, X4)
U135(X1, X2, X3, active(X4)) → U135(X1, X2, X3, X4)
U136(mark(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, mark(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, mark(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, mark(X4)) → U136(X1, X2, X3, X4)
U136(active(X1), X2, X3, X4) → U136(X1, X2, X3, X4)
U136(X1, active(X2), X3, X4) → U136(X1, X2, X3, X4)
U136(X1, X2, active(X3), X4) → U136(X1, X2, X3, X4)
U136(X1, X2, X3, active(X4)) → U136(X1, X2, X3, X4)
take(mark(X1), X2) → take(X1, X2)
take(X1, mark(X2)) → take(X1, X2)
take(active(X1), X2) → take(X1, X2)
take(X1, active(X2)) → take(X1, X2)
U21(mark(X1), X2) → U21(X1, X2)
U21(X1, mark(X2)) → U21(X1, X2)
U21(active(X1), X2) → U21(X1, X2)
U21(X1, active(X2)) → U21(X1, X2)
U22(mark(X1), X2) → U22(X1, X2)
U22(X1, mark(X2)) → U22(X1, X2)
U22(active(X1), X2) → U22(X1, X2)
U22(X1, active(X2)) → U22(X1, X2)
U23(mark(X)) → U23(X)
U23(active(X)) → U23(X)
U31(mark(X1), X2) → U31(X1, X2)
U31(X1, mark(X2)) → U31(X1, X2)
U31(active(X1), X2) → U31(X1, X2)
U31(X1, active(X2)) → U31(X1, X2)
U32(mark(X1), X2) → U32(X1, X2)
U32(X1, mark(X2)) → U32(X1, X2)
U32(active(X1), X2) → U32(X1, X2)
U32(X1, active(X2)) → U32(X1, X2)
U33(mark(X)) → U33(X)
U33(active(X)) → U33(X)
U41(mark(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, mark(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, mark(X3)) → U41(X1, X2, X3)
U41(active(X1), X2, X3) → U41(X1, X2, X3)
U41(X1, active(X2), X3) → U41(X1, X2, X3)
U41(X1, X2, active(X3)) → U41(X1, X2, X3)
U42(mark(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, mark(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, mark(X3)) → U42(X1, X2, X3)
U42(active(X1), X2, X3) → U42(X1, X2, X3)
U42(X1, active(X2), X3) → U42(X1, X2, X3)
U42(X1, X2, active(X3)) → U42(X1, X2, X3)
U43(mark(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, mark(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, mark(X3)) → U43(X1, X2, X3)
U43(active(X1), X2, X3) → U43(X1, X2, X3)
U43(X1, active(X2), X3) → U43(X1, X2, X3)
U43(X1, X2, active(X3)) → U43(X1, X2, X3)
U44(mark(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, mark(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, mark(X3)) → U44(X1, X2, X3)
U44(active(X1), X2, X3) → U44(X1, X2, X3)
U44(X1, active(X2), X3) → U44(X1, X2, X3)
U44(X1, X2, active(X3)) → U44(X1, X2, X3)
U45(mark(X1), X2) → U45(X1, X2)
U45(X1, mark(X2)) → U45(X1, X2)
U45(active(X1), X2) → U45(X1, X2)
U45(X1, active(X2)) → U45(X1, X2)
U46(mark(X)) → U46(X)
U46(active(X)) → U46(X)
U51(mark(X1), X2) → U51(X1, X2)
U51(X1, mark(X2)) → U51(X1, X2)
U51(active(X1), X2) → U51(X1, X2)
U51(X1, active(X2)) → U51(X1, X2)
U52(mark(X)) → U52(X)
U52(active(X)) → U52(X)
U61(mark(X1), X2) → U61(X1, X2)
U61(X1, mark(X2)) → U61(X1, X2)
U61(active(X1), X2) → U61(X1, X2)
U61(X1, active(X2)) → U61(X1, X2)
U62(mark(X)) → U62(X)
U62(active(X)) → U62(X)
U71(mark(X)) → U71(X)
U71(active(X)) → U71(X)
U81(mark(X)) → U81(X)
U81(active(X)) → U81(X)
U91(mark(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, mark(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, mark(X3)) → U91(X1, X2, X3)
U91(active(X1), X2, X3) → U91(X1, X2, X3)
U91(X1, active(X2), X3) → U91(X1, X2, X3)
U91(X1, X2, active(X3)) → U91(X1, X2, X3)
U92(mark(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, mark(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, mark(X3)) → U92(X1, X2, X3)
U92(active(X1), X2, X3) → U92(X1, X2, X3)
U92(X1, active(X2), X3) → U92(X1, X2, X3)
U92(X1, X2, active(X3)) → U92(X1, X2, X3)
U93(mark(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, mark(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, mark(X3)) → U93(X1, X2, X3)
U93(active(X1), X2, X3) → U93(X1, X2, X3)
U93(X1, active(X2), X3) → U93(X1, X2, X3)
U93(X1, X2, active(X3)) → U93(X1, X2, X3)
U94(mark(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, mark(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, mark(X3)) → U94(X1, X2, X3)
U94(active(X1), X2, X3) → U94(X1, X2, X3)
U94(X1, active(X2), X3) → U94(X1, X2, X3)
U94(X1, X2, active(X3)) → U94(X1, X2, X3)
U95(mark(X1), X2) → U95(X1, X2)
U95(X1, mark(X2)) → U95(X1, X2)
U95(active(X1), X2) → U95(X1, X2)
U95(X1, active(X2)) → U95(X1, X2)
U96(mark(X)) → U96(X)
U96(active(X)) → U96(X)