R
↳Dependency Pair Analysis
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(cons, app(f, x)), app(app(map, f), xs))
APP(app(map, f), app(app(cons, x), xs)) -> APP(cons, app(f, x))
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
R
↳DPs
→DP Problem 1
↳Narrowing Transformation
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(cons, app(f, x)), app(app(map, f), xs))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
four new Dependency Pairs are created:
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(cons, app(f, x)), app(app(map, f), xs))
APP(app(map, app(map, f'')), app(app(cons, nil), xs)) -> APP(app(cons, nil), app(app(map, app(map, f'')), xs))
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(cons, app(app(cons, app(f'', x'')), app(app(map, f''), xs''))), app(app(map, app(map, f'')), xs))
APP(app(map, f''), app(app(cons, x), nil)) -> APP(app(cons, app(f'', x)), nil)
APP(app(map, f''), app(app(cons, x), app(app(cons, x''), xs''))) -> APP(app(cons, app(f'', x)), app(app(cons, app(f'', x'')), app(app(map, f''), xs'')))
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Narrowing Transformation
APP(app(map, f''), app(app(cons, x), app(app(cons, x''), xs''))) -> APP(app(cons, app(f'', x)), app(app(cons, app(f'', x'')), app(app(map, f''), xs'')))
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(cons, app(app(cons, app(f'', x'')), app(app(map, f''), xs''))), app(app(map, app(map, f'')), xs))
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
six new Dependency Pairs are created:
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(cons, app(app(cons, app(f'', x'')), app(app(map, f''), xs''))), app(app(map, app(map, f'')), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, nil), xs'')), xs)) -> APP(app(cons, app(app(cons, nil), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, app(app(cons, x'), xs''')), xs'')), xs)) -> APP(app(cons, app(app(cons, app(app(cons, app(f', x')), app(app(map, f'), xs'''))), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), nil)), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), nil)), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), app(app(cons, x'), xs'''))), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(cons, app(f''', x')), app(app(map, f'''), xs''')))), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), nil)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), nil)
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), app(app(cons, x'), xs'''))) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), app(app(cons, app(app(map, f'''), x')), app(app(map, app(map, f''')), xs''')))
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 3
↳Narrowing Transformation
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), app(app(cons, x'), xs'''))) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), app(app(cons, app(app(map, f'''), x')), app(app(map, app(map, f''')), xs''')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), app(app(cons, x'), xs'''))), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(cons, app(f''', x')), app(app(map, f'''), xs''')))), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), nil)), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), nil)), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, app(app(cons, x'), xs''')), xs'')), xs)) -> APP(app(cons, app(app(cons, app(app(cons, app(f', x')), app(app(map, f'), xs'''))), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, nil), xs'')), xs)) -> APP(app(cons, app(app(cons, nil), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, f''), app(app(cons, x), app(app(cons, x''), xs''))) -> APP(app(cons, app(f'', x)), app(app(cons, app(f'', x'')), app(app(map, f''), xs'')))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
six new Dependency Pairs are created:
APP(app(map, f''), app(app(cons, x), app(app(cons, x''), xs''))) -> APP(app(cons, app(f'', x)), app(app(cons, app(f'', x'')), app(app(map, f''), xs'')))
APP(app(map, app(map, f')), app(app(cons, nil), app(app(cons, x''), xs''))) -> APP(app(cons, nil), app(app(cons, app(app(map, f'), x'')), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, app(app(cons, x'''), xs')), app(app(cons, x''), xs''))) -> APP(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(cons, app(app(map, f'), x'')), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, nil), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, nil), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, app(app(cons, x'''), xs')), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(map, app(map, f')), xs'')))
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), nil))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), nil))
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), app(app(cons, x'''), xs')))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), app(app(cons, app(f''', x''')), app(app(map, f'''), xs'))))
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 4
↳Forward Instantiation Transformation
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), app(app(cons, x'''), xs')))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), app(app(cons, app(f''', x''')), app(app(map, f'''), xs'))))
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), nil))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), nil))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, app(app(cons, x'''), xs')), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, nil), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, nil), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, app(app(cons, x'''), xs')), app(app(cons, x''), xs''))) -> APP(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(cons, app(app(map, f'), x'')), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), app(app(cons, x'), xs'''))), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(cons, app(f''', x')), app(app(map, f'''), xs''')))), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), nil)), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), nil)), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, app(app(cons, x'), xs''')), xs'')), xs)) -> APP(app(cons, app(app(cons, app(app(cons, app(f', x')), app(app(map, f'), xs'''))), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, nil), xs'')), xs)) -> APP(app(cons, app(app(cons, nil), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), app(app(cons, x'), xs'''))) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), app(app(cons, app(app(map, f'''), x')), app(app(map, app(map, f''')), xs''')))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
11 new Dependency Pairs are created:
APP(app(map, f), app(app(cons, x), xs)) -> APP(f, x)
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(map, f''), app(app(cons, x''), xs''))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, nil), xs'''')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, nil), xs'''')), xs''))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), nil)), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), nil)), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs''''''))), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs'''''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs'''''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, nil), xs''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, nil), xs'''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs'''''')))
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''), nil))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''), nil)))
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs''')))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs'''))))
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 5
↳Argument Filtering and Ordering
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs''')))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs'''))))
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''), nil))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''), nil)))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs'''''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs''''''))), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), nil)), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), nil)), xs''))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs''))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, nil), xs''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, nil), xs'''')))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, nil), xs'''')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, nil), xs'''')), xs''))
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(map, f''), app(app(cons, x''), xs''))
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), nil))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), nil))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, app(app(cons, x'''), xs')), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, nil), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, nil), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, app(app(cons, x'''), xs')), app(app(cons, x''), xs''))) -> APP(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(cons, app(app(map, f'), x'')), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), app(app(cons, x'), xs'''))) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), app(app(cons, app(app(map, f'''), x')), app(app(map, app(map, f''')), xs''')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), app(app(cons, x'), xs'''))), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(cons, app(f''', x')), app(app(map, f'''), xs''')))), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), nil)), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), nil)), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, app(app(cons, x'), xs''')), xs'')), xs)) -> APP(app(cons, app(app(cons, app(app(cons, app(f', x')), app(app(map, f'), xs'''))), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, nil), xs'')), xs)) -> APP(app(cons, app(app(cons, nil), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), app(app(cons, x'''), xs')))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), app(app(cons, app(f''', x''')), app(app(map, f'''), xs'))))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), nil))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), nil))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, app(app(cons, x'''), xs')), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, x), app(app(cons, nil), xs''))) -> APP(app(cons, app(app(map, f'), x)), app(app(cons, nil), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f')), app(app(cons, app(app(cons, x'''), xs')), app(app(cons, x''), xs''))) -> APP(app(cons, app(app(cons, app(f', x''')), app(app(map, f'), xs'))), app(app(cons, app(app(map, f'), x'')), app(app(map, app(map, f')), xs'')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), xs'')), app(app(cons, x'), xs'''))) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(map, f'''), xs''))), app(app(cons, app(app(map, f'''), x')), app(app(map, app(map, f''')), xs''')))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), app(app(cons, x'), xs'''))), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), app(app(cons, app(f''', x')), app(app(map, f'''), xs''')))), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x''), nil)), xs)) -> APP(app(cons, app(app(cons, app(f''', x'')), nil)), app(app(map, app(map, f''')), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, app(app(cons, x'), xs''')), xs'')), xs)) -> APP(app(cons, app(app(cons, app(app(cons, app(f', x')), app(app(map, f'), xs'''))), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, app(map, app(map, f'))), app(app(cons, app(app(cons, nil), xs'')), xs)) -> APP(app(cons, app(app(cons, nil), app(app(map, app(map, f')), xs''))), app(app(map, app(map, app(map, f'))), xs))
APP(app(map, f'''), app(app(cons, x), app(app(cons, x''), app(app(cons, x'''), xs')))) -> APP(app(cons, app(f''', x)), app(app(cons, app(f''', x'')), app(app(cons, app(f''', x''')), app(app(map, f'''), xs'))))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
{nil, map} > cons
APP(x1, x2) -> x1
app(x1, x2) -> x1
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 6
↳Argument Filtering and Ordering
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs''')))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs'''))))
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''), nil))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''), nil)))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs'''''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs''''''))), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), nil)), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), nil)), xs''))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs''))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, nil), xs''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, nil), xs'''')))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, nil), xs'''')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, nil), xs'''')), xs''))
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(map, f''), app(app(cons, x''), xs''))
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs''')))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''0), app(app(cons, x''''''), xs'''))))
APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''), app(app(cons, x''''), nil))), xs)) -> APP(app(map, f'''''), app(app(cons, x''), app(app(cons, x''''), nil)))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, app(app(cons, x'''''), xs''''')), xs'''''')))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs''''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, app(app(cons, x'''''), xs''''')), app(app(cons, x''0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs''''''))), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), xs''''0)), app(app(cons, x'0'), xs'''''')))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), app(app(cons, x'0'), xs'''''))), xs''))
APP(app(map, app(map, app(map, f'''''))), app(app(cons, app(app(cons, app(app(cons, x''''), nil)), xs'')), xs)) -> APP(app(map, app(map, f''''')), app(app(cons, app(app(cons, x''''), nil)), xs''))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, app(app(cons, x'''), xs''''')), xs''0')), xs''))
APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, x''), app(app(cons, nil), xs''''))), xs)) -> APP(app(map, app(map, f''')), app(app(cons, x''), app(app(cons, nil), xs'''')))
APP(app(map, app(map, app(map, app(map, f''')))), app(app(cons, app(app(cons, app(app(cons, nil), xs'''')), xs'')), xs)) -> APP(app(map, app(map, app(map, f'''))), app(app(cons, app(app(cons, nil), xs'''')), xs''))
APP(app(map, app(map, f'')), app(app(cons, app(app(cons, x''), xs'')), xs)) -> APP(app(map, f''), app(app(cons, x''), xs''))
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
trivial
APP(x1, x2) -> x1
app(x1, x2) -> app(x2)
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 7
↳Argument Filtering and Ordering
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost
APP(app(map, f), app(app(cons, x), xs)) -> APP(app(map, f), xs)
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
trivial
APP(x1, x2) -> APP(x1, x2)
app(x1, x2) -> app(x2)
R
↳DPs
→DP Problem 1
↳Nar
→DP Problem 2
↳Nar
...
→DP Problem 8
↳Dependency Graph
app(app(map, f), nil) -> nil
app(app(map, f), app(app(cons, x), xs)) -> app(app(cons, app(f, x)), app(app(map, f), xs))
innermost