per cases ( not p in rng f or p in rng f ) ;
suppose not p in rng f ; :: thesis: Rotate f,p is unfolded
end;
suppose A1: p in rng f ; :: thesis: Rotate f,p is unfolded
A2: len f > 4 by GOBOARD7:36;
let i be Nat; :: according to TOPREAL1:def 8 :: thesis: ( not 1 <= i or not i + 2 <= len (Rotate f,p) or (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))} )
assume that
A3: 1 <= i and
A4: i + 2 <= len (Rotate f,p) ; :: thesis: (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))}
A5: i in NAT by ORDINAL1:def 13;
thus (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))} :: thesis: verum
proof
A6: len f = len (Rotate f,p) by Th14;
i + 1 < i + 2 by XREAL_1:8;
then A7: i + 1 < len f by A4, A6, XXREAL_0:2;
A8: ((i + 1) -' 1) + (p .. f) = i + (p .. f) by NAT_D:34
.= ((i -' 1) + 1) + (p .. f) by A3, XREAL_1:237
.= ((i -' 1) + (p .. f)) + 1 ;
A9: len (f :- p) = ((len f) - (p .. f)) + 1 by A1, FINSEQ_5:53;
per cases ( i + 1 = len (f :- p) or i + 1 < len (f :- p) or len (f :- p) < i + 1 ) by XXREAL_0:1;
suppose A10: i + 1 = len (f :- p) ; :: thesis: (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))}
then A11: (i -' 1) + (p .. f) = (((((len f) - (p .. f)) + 1) - 1) - 1) + (p .. f) by A3, A9, XREAL_1:235
.= (((len f) - (p .. f)) + (p .. f)) - 1
.= (len f) -' 1 by A2, XREAL_1:235, XXREAL_0:2 ;
i < len (f :- p) by A10, XREAL_1:31;
then A12: LSeg (Rotate f,p),i = LSeg f,((len f) -' 1) by A1, A3, A5, A11, Th24;
((len (f :- p)) + (p .. f)) -' (len f) = ((len f) + 1) - (len f) by A9, NAT_1:11, XREAL_1:235
.= 1 ;
then LSeg (Rotate f,p),(len (f :- p)) = LSeg f,1 by A1, A7, A10, Th31;
hence (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {(f /. 1)} by A10, A12, Th30, GOBOARD7:36
.= {(f /. (len f))} by FINSEQ_6:def 1
.= {((Rotate f,p) /. (i + 1))} by A1, A10, Th11 ;
:: thesis: verum
end;
suppose A13: i + 1 < len (f :- p) ; :: thesis: (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))}
i + 0 < i + 1 by XREAL_1:8;
then i < len (f :- p) by A13, XXREAL_0:2;
then A14: LSeg (Rotate f,p),i = LSeg f,((i -' 1) + (p .. f)) by A1, A3, A5, Th24;
A15: LSeg (Rotate f,p),(i + 1) = LSeg f,(((i + 1) -' 1) + (p .. f)) by A1, A13, Th24, NAT_1:11;
( (i -' 1) + (p .. f) >= p .. f & p .. f >= 1 ) by A1, FINSEQ_4:31, NAT_1:11;
then A16: 1 <= (i -' 1) + (p .. f) by XXREAL_0:2;
i + 1 < ((len f) - (p .. f)) + 1 by A1, A13, FINSEQ_5:53;
then i < (len f) - (p .. f) by XREAL_1:8;
then i + (p .. f) < len f by XREAL_1:22;
then ((i -' 1) + 1) + (p .. f) < len f by A3, XREAL_1:237;
then (((i -' 1) + (p .. f)) + 1) + 1 <= len f by NAT_1:13;
then ((i -' 1) + (p .. f)) + (1 + 1) <= len f ;
hence (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {(f /. (((i + 1) -' 1) + (p .. f)))} by A8, A14, A15, A16, TOPREAL1:def 8
.= {((Rotate f,p) /. (i + 1))} by A1, A13, Th9, NAT_1:11 ;
:: thesis: verum
end;
suppose A17: len (f :- p) < i + 1 ; :: thesis: (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {((Rotate f,p) /. (i + 1))}
(i + 1) + 1 <= len f by A4, Th14;
then A18: i + 1 < len f by NAT_1:13;
i + 0 < i + 1 by XREAL_1:8;
then A19: i < len f by A18, XXREAL_0:2;
len (f :- p) <= i by A17, NAT_1:13;
then A20: LSeg (Rotate f,p),i = LSeg f,((i + (p .. f)) -' (len f)) by A1, A5, A19, Th31;
A21: LSeg (Rotate f,p),(i + 1) = LSeg f,(((i + 1) + (p .. f)) -' (len f)) by A1, A17, A18, Th31;
i + 1 > ((len f) - (p .. f)) + 1 by A1, A17, FINSEQ_5:53;
then (len f) - (p .. f) < i by XREAL_1:8;
then A22: len f < i + (p .. f) by XREAL_1:21;
then A23: (i + (p .. f)) -' (len f) = (i + (p .. f)) - (len f) by XREAL_1:235;
0 < (i + (p .. f)) - (len f) by A22, XREAL_1:52;
then A24: 0 + 1 <= (i + (p .. f)) -' (len f) by A23, NAT_1:13;
A25: ((i + 1) + (p .. f)) -' (len f) = ((i + (p .. f)) + 1) -' (len f)
.= ((i + (p .. f)) -' (len f)) + 1 by A22, NAT_D:38 ;
p .. f <= len f by A1, FINSEQ_4:31;
then (i + 2) + (p .. f) <= (len f) + (len f) by A4, A6, XREAL_1:9;
then ((i + (p .. f)) + 2) - (len f) <= len f by XREAL_1:22;
then ((i + (p .. f)) - (len f)) + 2 <= len f ;
hence (LSeg (Rotate f,p),i) /\ (LSeg (Rotate f,p),(i + 1)) = {(f /. (((i + 1) + (p .. f)) -' (len f)))} by A20, A21, A23, A24, A25, TOPREAL1:def 8
.= {((Rotate f,p) /. (i + 1))} by A1, A7, A17, Th17 ;
:: thesis: verum
end;
end;
end;
end;
end;