MAYBE
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http:/www.w3.org/TR/html4/frameset.dtd">
<html>
<head>
<title>Left Termination proof of ../tpdb/LP/terminweb/old-terminweb/subset-no.pl</title>
</head>
<body>
<BR><B>Left Termination</B> of the query pattern
subset_in_2(a, g)
w.r.t. the given <I>Prolog program</I> could not be shown:<BR><BR><BR><BR><pre>&#8627 <B>Prolog</B></pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Clauses:<BR><BR>member(X, .(Y, Xs))&#160;:-&#160;member(X, Xs).<BR>member(X, .(X, Xs)).<BR>subset(.(X, Xs), Ys)&#160;:-&#160;','(member(X, Ys), subset(Xs, Ys)).<BR>subset([], Ys).<BR><BR>Queries:<BR><BR>subset(a,g).<BR><BR>We use the technique of [30]. With regard to the inferred argument filtering the predicates were used in the following modes:
<BR><FONT COLOR=#0000cc>subset_in</font>: (f,b)
<BR><FONT COLOR=#0000cc>member_in</font>: (f,b)
<BR>Transforming <I>Prolog</I> into the following <B>Term Rewriting System</B>:
<BR>Pi-finite rewrite system:<BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<BR>
<P><B>Infinitary Constructor Rewriting Termination</B> of PiTRS implies <B>Termination</B> of Prolog<P>
<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 <B>PiTRS</B></pre><pre>      &#8627 DependencyPairsProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi-finite rewrite system:<BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<BR><BR>Using Dependency Pairs [1,30] we result in the following initial DP problem:<BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 <B>PiDP</B></pre><pre>          &#8627 DependencyGraphProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>The approximation of the Dependency Graph [30] contains 2 SCCs with 3 less nodes.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 <B>PiDP</B></pre><pre>                &#8627 UsableRulesProof</pre><pre>              &#8627 PiDP</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>For (infinitary) constructor rewriting [30] we can delete all non-usable rules from R.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 <B>PiDP</B></pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>              &#8627 PiDP</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>R is empty.<BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>Transforming (infinitary) constructor rewriting Pi-DP problem [30] into ordinary QDP problem [15] by application of Pi.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 <B>QDP</B></pre><pre>                        &#8627 QDPSizeChangeProof</pre><pre>              &#8627 PiDP</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>R is empty.<BR>Q is empty.<BR>We have to consider all (P,Q,R)-chains.<BR>By using the subterm criterion [20] together with the size-change analysis [32] we have proven that there are no infinite chains for this DP problem. <P>From the DPs we obtained the following set of size-change graphs:
<UL><LI><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>)<BR>The graph contains the following edges 1 > 1<P></LI></UL><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 <B>PiDP</B></pre><pre>                &#8627 UsableRulesProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>For (infinitary) constructor rewriting [30] we can delete all non-usable rules from R.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 <B>PiDP</B></pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>Transforming (infinitary) constructor rewriting Pi-DP problem [30] into ordinary QDP problem [15] by application of Pi.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 <B>QDP</B></pre><pre>                        &#8627 Narrowing</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>By narrowing [15] the rule <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Ys</font>)) at position [1] we obtained the following new rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>))</BLOCKQUOTE><BR><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 QDP</pre><pre>                        &#8627 Narrowing</pre><pre>                          &#8627 <B>QDP</B></pre><pre>                            &#8627 Instantiation</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>By instantiating [15] the rule <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) we obtained the following new rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))</BLOCKQUOTE><BR><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 QDP</pre><pre>                        &#8627 Narrowing</pre><pre>                          &#8627 QDP</pre><pre>                            &#8627 Instantiation</pre><pre>                              &#8627 <B>QDP</B></pre><pre>                                &#8627 NonTerminationProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>We used the non-termination processor [17] to show that the DP problem is infinite.<BR>Found a loop by narrowing to the left:<BR><BR>The TRS P consists of the following rules:<BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>)</BLOCKQUOTE><BR><BR>s = <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>)) evaluates to  t =<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>))<BR><BR>Thus s starts an infinite chain as s semiunifies with t with the following substitutions:<BR><UL><LI> Semiunifier: [ ]</LI>
<LI> Matcher: [ ]</LI></UL><BR><BR><hr><BR><B>Rewriting sequence</B><BR><BR><B><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>))</B> &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))<BR>with rule <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0'</font>, <FONT COLOR=#cc0000>z1'</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0'</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0'</font>, <FONT COLOR=#cc0000>z1'</font>)) at position [] and matcher [<FONT COLOR=#cc0000>z1'</font> / <FONT COLOR=#cc0000>z1</font>, <FONT COLOR=#cc0000>z0'</font> / <FONT COLOR=#cc0000>z0</font>]<BR><BR><B><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))</B> &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>))<BR>with rule <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>))<BR><BR>Now applying the matcher to the start term leads to a term which is equal to the last term in the rewriting sequence<BR><BR><BR>All these steps are and every following step will be a correct step w.r.t to Q.<BR><BR><BR><BR><BR>We use the technique of [30]. With regard to the inferred argument filtering the predicates were used in the following modes:
<BR><FONT COLOR=#0000cc>subset_in</font>: (f,b)
<BR><FONT COLOR=#0000cc>member_in</font>: (f,b)
<BR>Transforming <I>Prolog</I> into the following <B>Term Rewriting System</B>:
<BR>Pi-finite rewrite system:<BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<BR>
<P><B>Infinitary Constructor Rewriting Termination</B> of PiTRS implies <B>Termination</B> of Prolog<P>
<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 <B>PiTRS</B></pre><pre>      &#8627 DependencyPairsProof</pre><BR>Pi-finite rewrite system:<BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<BR><BR>Using Dependency Pairs [1,30] we result in the following initial DP problem:<BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 <B>PiDP</B></pre><pre>          &#8627 DependencyGraphProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_AG</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>The approximation of the Dependency Graph [30] contains 2 SCCs with 3 less nodes.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 <B>PiDP</B></pre><pre>                &#8627 UsableRulesProof</pre><pre>              &#8627 PiDP</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>For (infinitary) constructor rewriting [30] we can delete all non-usable rules from R.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 <B>PiDP</B></pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>              &#8627 PiDP</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>R is empty.<BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>Transforming (infinitary) constructor rewriting Pi-DP problem [30] into ordinary QDP problem [15] by application of Pi.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 <B>QDP</B></pre><pre>                        &#8627 QDPSizeChangeProof</pre><pre>              &#8627 PiDP</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>)</BLOCKQUOTE><BR>R is empty.<BR>Q is empty.<BR>We have to consider all (P,Q,R)-chains.<BR>By using the subterm criterion [20] together with the size-change analysis [32] we have proven that there are no infinite chains for this DP problem. <P>From the DPs we obtained the following set of size-change graphs:
<UL><LI><FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>MEMBER_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>)<BR>The graph contains the following edges 1 > 1<P></LI></UL><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 <B>PiDP</B></pre><pre>                &#8627 UsableRulesProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>))
<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>[]</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_ag</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U3_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>subset_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>For (infinitary) constructor rewriting [30] we can delete all non-usable rules from R.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 <B>PiDP</B></pre><pre>                    &#8627 PiDPToQDPProof</pre><BR>Pi DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>), <FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR>The argument filtering Pi contains the following mapping:<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)&#160; = &#160;<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>x2</font>)<BR>
<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>, <FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)&#160; = &#160;<FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>x3</font>, <FONT COLOR=#cc0000>x4</font>)<BR>
<BR>We have to consider all (P,R,Pi)-chains<BR>Transforming (infinitary) constructor rewriting Pi-DP problem [30] into ordinary QDP problem [15] by application of Pi.<BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 <B>QDP</B></pre><pre>                        &#8627 Narrowing</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>)
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Ys</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>By narrowing [15] the rule <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Ys</font>)) at position [1] we obtained the following new rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))</BLOCKQUOTE><BR><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 QDP</pre><pre>                        &#8627 Narrowing</pre><pre>                          &#8627 <B>QDP</B></pre><pre>                            &#8627 Instantiation</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>)</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>By instantiating [15] the rule <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#cc0000>Ys</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Ys</font>)) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#cc0000>Ys</font>) we obtained the following new rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))</BLOCKQUOTE><BR><BR><BR><pre>&#8627 Prolog</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>  &#8627 PrologToPiTRSProof</pre><pre>    &#8627 PiTRS</pre><pre>      &#8627 DependencyPairsProof</pre><pre>        &#8627 PiDP</pre><pre>          &#8627 DependencyGraphProof</pre><pre>            &#8627 AND</pre><pre>              &#8627 PiDP</pre><pre>              &#8627 PiDP</pre><pre>                &#8627 UsableRulesProof</pre><pre>                  &#8627 PiDP</pre><pre>                    &#8627 PiDPToQDPProof</pre><pre>                      &#8627 QDP</pre><pre>                        &#8627 Narrowing</pre><pre>                          &#8627 QDP</pre><pre>                            &#8627 Instantiation</pre><pre>                              &#8627 <B>QDP</B></pre><pre>                                &#8627 NonTerminationProof</pre><BR>Q DP problem:<BR>The TRS P consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR>The set Q consists of the following terms:<BR><BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x0</font>)
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x2</font>)</BLOCKQUOTE><BR>We have to consider all (P,Q,R)-chains.<BR>We used the non-termination processor [17] to show that the DP problem is infinite.<BR>Found a loop by narrowing to the left:<BR><BR>The TRS P consists of the following rules:<BLOCKQUOTE><BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>x1</font>)))
<BR><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))</BLOCKQUOTE><BR>The TRS R consists of the following rules:<BLOCKQUOTE><BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>member_in_ag</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>))
<BR><FONT COLOR=#0000cc>U1_ag</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>, <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#cc0000>Xs</font>)) &#8594; <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>X</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>Y</font>, <FONT COLOR=#cc0000>Xs</font>))</BLOCKQUOTE><BR><BR>s = <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)) evaluates to  t =<FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>))<BR><BR>Thus s starts an infinite chain as s semiunifies with t with the following substitutions:<BR><UL><LI> Semiunifier: [ ]</LI>
<LI> Matcher: [ ]</LI></UL><BR><BR><hr><BR><B>Rewriting sequence</B><BR><BR><B><FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>))</B> &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))<BR>with rule <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0'</font>, <FONT COLOR=#cc0000>x1'</font>)) &#8594; <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0'</font>, <FONT COLOR=#cc0000>x1'</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0'</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0'</font>, <FONT COLOR=#cc0000>x1'</font>))) at position [] and matcher [<FONT COLOR=#cc0000>x1'</font> / <FONT COLOR=#cc0000>x1</font>, <FONT COLOR=#cc0000>x0'</font> / <FONT COLOR=#cc0000>x0</font>]<BR><BR><B><FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>)))</B> &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>x0</font>, <FONT COLOR=#cc0000>x1</font>))<BR>with rule <FONT COLOR=#0000cc>U2_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>), <FONT COLOR=#0000cc>member_out_ag</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))) &#8594; <FONT COLOR=#0000cc>SUBSET_IN_AG</font>(<FONT COLOR=#0000cc>.</font>(<FONT COLOR=#cc0000>z0</font>, <FONT COLOR=#cc0000>z1</font>))<BR><BR>Now applying the matcher to the start term leads to a term which is equal to the last term in the rewriting sequence<BR><BR><BR>All these steps are and every following step will be a correct step w.r.t to Q.<BR><BR><BR><BR><BR><BR></body>


