let it1, it2 be Element of NAT ; :: thesis: ( ex k being Element of NAT st
( it1 = k & ((StepWhile>0 (a,I,p,s)) . k) . a <= 0 & ( for i being Element of NAT st ((StepWhile>0 (a,I,p,s)) . i) . a <= 0 holds
k <= i ) & DataPart (Comput ((p +* (while>0 (a,I))),(Initialize s),(LifeSpan ((p +* (while>0 (a,I))),(Initialize s))))) = DataPart ((StepWhile>0 (a,I,p,s)) . k) ) & ex k being Element of NAT st
( it2 = k & ((StepWhile>0 (a,I,p,s)) . k) . a <= 0 & ( for i being Element of NAT st ((StepWhile>0 (a,I,p,s)) . i) . a <= 0 holds
k <= i ) & DataPart (Comput ((p +* (while>0 (a,I))),(Initialize s),(LifeSpan ((p +* (while>0 (a,I))),(Initialize s))))) = DataPart ((StepWhile>0 (a,I,p,s)) . k) ) implies it1 = it2 )

given k1 being Element of NAT such that A35: it1 = k1 and
A36: ( ((StepWhile>0 (a,I,p,s)) . k1) . a <= 0 & ( for i being Element of NAT st ((StepWhile>0 (a,I,p,s)) . i) . a <= 0 holds
k1 <= i ) ) and
DataPart (Comput ((p +* (while>0 (a,I))),(Initialize s),(LifeSpan ((p +* (while>0 (a,I))),(Initialize s))))) = DataPart ((StepWhile>0 (a,I,p,s)) . k1) ; :: thesis: ( for k being Element of NAT holds
( not it2 = k or not ((StepWhile>0 (a,I,p,s)) . k) . a <= 0 or ex i being Element of NAT st
( ((StepWhile>0 (a,I,p,s)) . i) . a <= 0 & not k <= i ) or not DataPart (Comput ((p +* (while>0 (a,I))),(Initialize s),(LifeSpan ((p +* (while>0 (a,I))),(Initialize s))))) = DataPart ((StepWhile>0 (a,I,p,s)) . k) ) or it1 = it2 )

given k2 being Element of NAT such that A37: it2 = k2 and
A38: ( ((StepWhile>0 (a,I,p,s)) . k2) . a <= 0 & ( for i being Element of NAT st ((StepWhile>0 (a,I,p,s)) . i) . a <= 0 holds
k2 <= i ) ) and
DataPart (Comput ((p +* (while>0 (a,I))),(Initialize s),(LifeSpan ((p +* (while>0 (a,I))),(Initialize s))))) = DataPart ((StepWhile>0 (a,I,p,s)) . k2) ; :: thesis: it1 = it2
( k1 <= k2 & k2 <= k1 ) by A36, A38;
hence it1 = it2 by A35, A37, XXREAL_0:1; :: thesis: verum