MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  crctcshwlkn0lem5 Structured version   Visualization version   GIF version

Theorem crctcshwlkn0lem5 29847
Description: Lemma for crctcshwlkn0 29854. (Contributed by AV, 12-Mar-2021.)
Hypotheses
Ref Expression
crctcshwlkn0lem.s (𝜑𝑆 ∈ (1..^𝑁))
crctcshwlkn0lem.q 𝑄 = (𝑥 ∈ (0...𝑁) ↦ if(𝑥 ≤ (𝑁𝑆), (𝑃‘(𝑥 + 𝑆)), (𝑃‘((𝑥 + 𝑆) − 𝑁))))
crctcshwlkn0lem.h 𝐻 = (𝐹 cyclShift 𝑆)
crctcshwlkn0lem.n 𝑁 = (♯‘𝐹)
crctcshwlkn0lem.f (𝜑𝐹 ∈ Word 𝐴)
crctcshwlkn0lem.p (𝜑 → ∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))))
Assertion
Ref Expression
crctcshwlkn0lem5 (𝜑 → ∀𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)if-((𝑄𝑗) = (𝑄‘(𝑗 + 1)), (𝐼‘(𝐻𝑗)) = {(𝑄𝑗)}, {(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗))))
Distinct variable groups:   𝑥,𝑁   𝑥,𝑃   𝑥,𝑆   𝜑,𝑥   𝑖,𝐹   𝑖,𝐼   𝑖,𝑁   𝑃,𝑖   𝑆,𝑖   𝜑,𝑖,𝑗   𝑥,𝑗
Allowed substitution hints:   𝐴(𝑥,𝑖,𝑗)   𝑃(𝑗)   𝑄(𝑥,𝑖,𝑗)   𝑆(𝑗)   𝐹(𝑥,𝑗)   𝐻(𝑥,𝑖,𝑗)   𝐼(𝑥,𝑗)   𝑁(𝑗)

Proof of Theorem crctcshwlkn0lem5
StepHypRef Expression
1 crctcshwlkn0lem.p . . . . 5 (𝜑 → ∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))))
2 crctcshwlkn0lem.s . . . . . . 7 (𝜑𝑆 ∈ (1..^𝑁))
3 elfzoelz 13716 . . . . . . . . . . . 12 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → 𝑗 ∈ ℤ)
43zcnd 12748 . . . . . . . . . . 11 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → 𝑗 ∈ ℂ)
54adantl 481 . . . . . . . . . 10 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑗 ∈ ℂ)
6 1cnd 11285 . . . . . . . . . 10 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 1 ∈ ℂ)
7 elfzoelz 13716 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ ℤ)
87zcnd 12748 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ ℂ)
98adantr 480 . . . . . . . . . 10 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑆 ∈ ℂ)
10 elfzoel2 13715 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℤ)
1110zcnd 12748 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℂ)
1211adantr 480 . . . . . . . . . 10 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑁 ∈ ℂ)
135, 6, 9, 122addsubd 11697 . . . . . . . . 9 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (((𝑗 + 1) + 𝑆) − 𝑁) = (((𝑗 + 𝑆) − 𝑁) + 1))
1413eqcomd 2746 . . . . . . . 8 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁))
15 elfzo1 13766 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) ↔ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁))
16 nnz 12660 . . . . . . . . . . . . . . . . 17 (𝑁 ∈ ℕ → 𝑁 ∈ ℤ)
17163ad2ant2 1134 . . . . . . . . . . . . . . . 16 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ∈ ℤ)
1817adantr 480 . . . . . . . . . . . . . . 15 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑁 ∈ ℤ)
193adantl 481 . . . . . . . . . . . . . . . 16 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑗 ∈ ℤ)
20 nnz 12660 . . . . . . . . . . . . . . . . . 18 (𝑆 ∈ ℕ → 𝑆 ∈ ℤ)
21203ad2ant1 1133 . . . . . . . . . . . . . . . . 17 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑆 ∈ ℤ)
2221adantr 480 . . . . . . . . . . . . . . . 16 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑆 ∈ ℤ)
2319, 22zaddcld 12751 . . . . . . . . . . . . . . 15 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝑗 + 𝑆) ∈ ℤ)
24 elfzo2 13719 . . . . . . . . . . . . . . . . 17 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) ↔ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁))
25 eluz2 12909 . . . . . . . . . . . . . . . . . . . 20 (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ↔ (((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑗 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑗))
26 zre 12643 . . . . . . . . . . . . . . . . . . . . . . . 24 (𝑗 ∈ ℤ → 𝑗 ∈ ℝ)
27 nnre 12300 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑆 ∈ ℕ → 𝑆 ∈ ℝ)
28 nnre 12300 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ)
2927, 28anim12i 612 . . . . . . . . . . . . . . . . . . . . . . . . . 26 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ))
30 simplr 768 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → 𝑁 ∈ ℝ)
31 simpll 766 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → 𝑆 ∈ ℝ)
3230, 31resubcld 11718 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → (𝑁𝑆) ∈ ℝ)
3332lep1d 12226 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → (𝑁𝑆) ≤ ((𝑁𝑆) + 1))
34 1red 11291 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → 1 ∈ ℝ)
3532, 34readdcld 11319 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → ((𝑁𝑆) + 1) ∈ ℝ)
36 simpr 484 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → 𝑗 ∈ ℝ)
37 letr 11384 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 (((𝑁𝑆) ∈ ℝ ∧ ((𝑁𝑆) + 1) ∈ ℝ ∧ 𝑗 ∈ ℝ) → (((𝑁𝑆) ≤ ((𝑁𝑆) + 1) ∧ ((𝑁𝑆) + 1) ≤ 𝑗) → (𝑁𝑆) ≤ 𝑗))
3832, 35, 36, 37syl3anc 1371 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → (((𝑁𝑆) ≤ ((𝑁𝑆) + 1) ∧ ((𝑁𝑆) + 1) ≤ 𝑗) → (𝑁𝑆) ≤ 𝑗))
3933, 38mpand 694 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → (((𝑁𝑆) + 1) ≤ 𝑗 → (𝑁𝑆) ≤ 𝑗))
4030, 31, 36lesubaddd 11887 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → ((𝑁𝑆) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆)))
4139, 40sylibd 239 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℝ) → (((𝑁𝑆) + 1) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆)))
4241ex 412 . . . . . . . . . . . . . . . . . . . . . . . . . 26 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝑗 ∈ ℝ → (((𝑁𝑆) + 1) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆))))
4329, 42syl 17 . . . . . . . . . . . . . . . . . . . . . . . . 25 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑗 ∈ ℝ → (((𝑁𝑆) + 1) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆))))
44433adant3 1132 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑗 ∈ ℝ → (((𝑁𝑆) + 1) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆))))
4526, 44syl5com 31 . . . . . . . . . . . . . . . . . . . . . . 23 (𝑗 ∈ ℤ → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (((𝑁𝑆) + 1) ≤ 𝑗𝑁 ≤ (𝑗 + 𝑆))))
4645com23 86 . . . . . . . . . . . . . . . . . . . . . 22 (𝑗 ∈ ℤ → (((𝑁𝑆) + 1) ≤ 𝑗 → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆))))
4746imp 406 . . . . . . . . . . . . . . . . . . . . 21 ((𝑗 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑗) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
48473adant1 1130 . . . . . . . . . . . . . . . . . . . 20 ((((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑗 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑗) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
4925, 48sylbi 217 . . . . . . . . . . . . . . . . . . 19 (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
50493ad2ant1 1133 . . . . . . . . . . . . . . . . . 18 ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
5150com12 32 . . . . . . . . . . . . . . . . 17 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
5224, 51biimtrid 242 . . . . . . . . . . . . . . . 16 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → 𝑁 ≤ (𝑗 + 𝑆)))
5352imp 406 . . . . . . . . . . . . . . 15 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑁 ≤ (𝑗 + 𝑆))
54 eluz2 12909 . . . . . . . . . . . . . . 15 ((𝑗 + 𝑆) ∈ (ℤ𝑁) ↔ (𝑁 ∈ ℤ ∧ (𝑗 + 𝑆) ∈ ℤ ∧ 𝑁 ≤ (𝑗 + 𝑆)))
5518, 23, 53, 54syl3anbrc 1343 . . . . . . . . . . . . . 14 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝑗 + 𝑆) ∈ (ℤ𝑁))
56 uznn0sub 12942 . . . . . . . . . . . . . 14 ((𝑗 + 𝑆) ∈ (ℤ𝑁) → ((𝑗 + 𝑆) − 𝑁) ∈ ℕ0)
5755, 56syl 17 . . . . . . . . . . . . 13 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝑗 + 𝑆) − 𝑁) ∈ ℕ0)
58 simpl2 1192 . . . . . . . . . . . . 13 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑁 ∈ ℕ)
5926adantl 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → 𝑗 ∈ ℝ)
60 simpll 766 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → 𝑆 ∈ ℝ)
61 ax-1 6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 (𝑁 ∈ ℝ → (𝑆 ∈ ℝ → 𝑁 ∈ ℝ))
6261imdistanri 569 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝑁 ∈ ℝ ∧ 𝑁 ∈ ℝ))
6362adantr 480 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → (𝑁 ∈ ℝ ∧ 𝑁 ∈ ℝ))
64 lt2add 11775 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑗 ∈ ℝ ∧ 𝑆 ∈ ℝ) ∧ (𝑁 ∈ ℝ ∧ 𝑁 ∈ ℝ)) → ((𝑗 < 𝑁𝑆 < 𝑁) → (𝑗 + 𝑆) < (𝑁 + 𝑁)))
6559, 60, 63, 64syl21anc 837 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → ((𝑗 < 𝑁𝑆 < 𝑁) → (𝑗 + 𝑆) < (𝑁 + 𝑁)))
6659, 60readdcld 11319 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → (𝑗 + 𝑆) ∈ ℝ)
67 simplr 768 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → 𝑁 ∈ ℝ)
6866, 67, 67ltsubaddd 11886 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → (((𝑗 + 𝑆) − 𝑁) < 𝑁 ↔ (𝑗 + 𝑆) < (𝑁 + 𝑁)))
6965, 68sylibrd 259 . . . . . . . . . . . . . . . . . . . . . . . . 25 (((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝑗 ∈ ℤ) → ((𝑗 < 𝑁𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁))
7069ex 412 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝑗 ∈ ℤ → ((𝑗 < 𝑁𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
7170com23 86 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → ((𝑗 < 𝑁𝑆 < 𝑁) → (𝑗 ∈ ℤ → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
7271expcomd 416 . . . . . . . . . . . . . . . . . . . . . 22 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝑆 < 𝑁 → (𝑗 < 𝑁 → (𝑗 ∈ ℤ → ((𝑗 + 𝑆) − 𝑁) < 𝑁))))
7329, 72syl 17 . . . . . . . . . . . . . . . . . . . . 21 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 < 𝑁 → (𝑗 < 𝑁 → (𝑗 ∈ ℤ → ((𝑗 + 𝑆) − 𝑁) < 𝑁))))
74733impia 1117 . . . . . . . . . . . . . . . . . . . 20 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑗 < 𝑁 → (𝑗 ∈ ℤ → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
7574com13 88 . . . . . . . . . . . . . . . . . . 19 (𝑗 ∈ ℤ → (𝑗 < 𝑁 → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
76753ad2ant2 1134 . . . . . . . . . . . . . . . . . 18 ((((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑗 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑗) → (𝑗 < 𝑁 → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
7725, 76sylbi 217 . . . . . . . . . . . . . . . . 17 (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) → (𝑗 < 𝑁 → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁)))
7877imp 406 . . . . . . . . . . . . . . . 16 ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑗 < 𝑁) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁))
79783adant2 1131 . . . . . . . . . . . . . . 15 ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁))
8024, 79sylbi 217 . . . . . . . . . . . . . 14 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 + 𝑆) − 𝑁) < 𝑁))
8180impcom 407 . . . . . . . . . . . . 13 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝑗 + 𝑆) − 𝑁) < 𝑁)
8257, 58, 813jca 1128 . . . . . . . . . . . 12 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (((𝑗 + 𝑆) − 𝑁) ∈ ℕ0𝑁 ∈ ℕ ∧ ((𝑗 + 𝑆) − 𝑁) < 𝑁))
8315, 82sylanb 580 . . . . . . . . . . 11 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (((𝑗 + 𝑆) − 𝑁) ∈ ℕ0𝑁 ∈ ℕ ∧ ((𝑗 + 𝑆) − 𝑁) < 𝑁))
84 elfzo0 13757 . . . . . . . . . . 11 (((𝑗 + 𝑆) − 𝑁) ∈ (0..^𝑁) ↔ (((𝑗 + 𝑆) − 𝑁) ∈ ℕ0𝑁 ∈ ℕ ∧ ((𝑗 + 𝑆) − 𝑁) < 𝑁))
8583, 84sylibr 234 . . . . . . . . . 10 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝑗 + 𝑆) − 𝑁) ∈ (0..^𝑁))
8685adantr 480 . . . . . . . . 9 (((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) → ((𝑗 + 𝑆) − 𝑁) ∈ (0..^𝑁))
87 fveq2 6920 . . . . . . . . . . . 12 (𝑖 = ((𝑗 + 𝑆) − 𝑁) → (𝑃𝑖) = (𝑃‘((𝑗 + 𝑆) − 𝑁)))
8887adantl 481 . . . . . . . . . . 11 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → (𝑃𝑖) = (𝑃‘((𝑗 + 𝑆) − 𝑁)))
89 fvoveq1 7471 . . . . . . . . . . . 12 (𝑖 = ((𝑗 + 𝑆) − 𝑁) → (𝑃‘(𝑖 + 1)) = (𝑃‘(((𝑗 + 𝑆) − 𝑁) + 1)))
90 simpr 484 . . . . . . . . . . . . 13 (((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) → (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁))
9190fveq2d 6924 . . . . . . . . . . . 12 (((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) → (𝑃‘(((𝑗 + 𝑆) − 𝑁) + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)))
9289, 91sylan9eqr 2802 . . . . . . . . . . 11 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → (𝑃‘(𝑖 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)))
9388, 92eqeq12d 2756 . . . . . . . . . 10 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → ((𝑃𝑖) = (𝑃‘(𝑖 + 1)) ↔ (𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))))
94 2fveq3 6925 . . . . . . . . . . . 12 (𝑖 = ((𝑗 + 𝑆) − 𝑁) → (𝐼‘(𝐹𝑖)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))
9587sneqd 4660 . . . . . . . . . . . 12 (𝑖 = ((𝑗 + 𝑆) − 𝑁) → {(𝑃𝑖)} = {(𝑃‘((𝑗 + 𝑆) − 𝑁))})
9694, 95eqeq12d 2756 . . . . . . . . . . 11 (𝑖 = ((𝑗 + 𝑆) − 𝑁) → ((𝐼‘(𝐹𝑖)) = {(𝑃𝑖)} ↔ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}))
9796adantl 481 . . . . . . . . . 10 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → ((𝐼‘(𝐹𝑖)) = {(𝑃𝑖)} ↔ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}))
9888, 92preq12d 4766 . . . . . . . . . . 11 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → {(𝑃𝑖), (𝑃‘(𝑖 + 1))} = {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))})
99 simpr 484 . . . . . . . . . . . . 13 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → 𝑖 = ((𝑗 + 𝑆) − 𝑁))
10099fveq2d 6924 . . . . . . . . . . . 12 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → (𝐹𝑖) = (𝐹‘((𝑗 + 𝑆) − 𝑁)))
101100fveq2d 6924 . . . . . . . . . . 11 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → (𝐼‘(𝐹𝑖)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))
10298, 101sseq12d 4042 . . . . . . . . . 10 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → ({(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖)) ↔ {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))))
10393, 97, 102ifpbi123d 1079 . . . . . . . . 9 ((((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) ∧ 𝑖 = ((𝑗 + 𝑆) − 𝑁)) → (if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) ↔ if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
10486, 103rspcdv 3627 . . . . . . . 8 (((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) ∧ (((𝑗 + 𝑆) − 𝑁) + 1) = (((𝑗 + 1) + 𝑆) − 𝑁)) → (∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
10514, 104mpdan 686 . . . . . . 7 ((𝑆 ∈ (1..^𝑁) ∧ 𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
1062, 105sylan 579 . . . . . 6 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
107106ex 412 . . . . 5 (𝜑 → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → (∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))))))
1081, 107mpid 44 . . . 4 (𝜑 → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
109108imp 406 . . 3 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))))
110 elfzofz 13732 . . . . 5 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → 𝑗 ∈ (((𝑁𝑆) + 1)...𝑁))
111 crctcshwlkn0lem.q . . . . . 6 𝑄 = (𝑥 ∈ (0...𝑁) ↦ if(𝑥 ≤ (𝑁𝑆), (𝑃‘(𝑥 + 𝑆)), (𝑃‘((𝑥 + 𝑆) − 𝑁))))
1122, 111crctcshwlkn0lem3 29845 . . . . 5 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)...𝑁)) → (𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)))
113110, 112sylan2 592 . . . 4 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)))
114 fzofzp1 13814 . . . . 5 (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → (𝑗 + 1) ∈ (((𝑁𝑆) + 1)...𝑁))
1152, 111crctcshwlkn0lem3 29845 . . . . 5 ((𝜑 ∧ (𝑗 + 1) ∈ (((𝑁𝑆) + 1)...𝑁)) → (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)))
116114, 115sylan2 592 . . . 4 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)))
117 crctcshwlkn0lem.h . . . . . . 7 𝐻 = (𝐹 cyclShift 𝑆)
118117fveq1i 6921 . . . . . 6 (𝐻𝑗) = ((𝐹 cyclShift 𝑆)‘𝑗)
119 crctcshwlkn0lem.f . . . . . . . . 9 (𝜑𝐹 ∈ Word 𝐴)
120119adantr 480 . . . . . . . 8 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝐹 ∈ Word 𝐴)
1212, 7syl 17 . . . . . . . . 9 (𝜑𝑆 ∈ ℤ)
122121adantr 480 . . . . . . . 8 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑆 ∈ ℤ)
123 ltle 11378 . . . . . . . . . . . . . . . . 17 ((𝑆 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝑆 < 𝑁𝑆𝑁))
12429, 123syl 17 . . . . . . . . . . . . . . . 16 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 < 𝑁𝑆𝑁))
1251243impia 1117 . . . . . . . . . . . . . . 15 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑆𝑁)
126 nnnn0 12560 . . . . . . . . . . . . . . . . . 18 (𝑆 ∈ ℕ → 𝑆 ∈ ℕ0)
127 nnnn0 12560 . . . . . . . . . . . . . . . . . 18 (𝑁 ∈ ℕ → 𝑁 ∈ ℕ0)
128126, 127anim12i 612 . . . . . . . . . . . . . . . . 17 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 ∈ ℕ0𝑁 ∈ ℕ0))
1291283adant3 1132 . . . . . . . . . . . . . . . 16 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑆 ∈ ℕ0𝑁 ∈ ℕ0))
130 nn0sub 12603 . . . . . . . . . . . . . . . 16 ((𝑆 ∈ ℕ0𝑁 ∈ ℕ0) → (𝑆𝑁 ↔ (𝑁𝑆) ∈ ℕ0))
131129, 130syl 17 . . . . . . . . . . . . . . 15 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑆𝑁 ↔ (𝑁𝑆) ∈ ℕ0))
132125, 131mpbid 232 . . . . . . . . . . . . . 14 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑁𝑆) ∈ ℕ0)
13315, 132sylbi 217 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ ℕ0)
134 1nn0 12569 . . . . . . . . . . . . . 14 1 ∈ ℕ0
135134a1i 11 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → 1 ∈ ℕ0)
136133, 135nn0addcld 12617 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → ((𝑁𝑆) + 1) ∈ ℕ0)
137 elnn0uz 12948 . . . . . . . . . . . 12 (((𝑁𝑆) + 1) ∈ ℕ0 ↔ ((𝑁𝑆) + 1) ∈ (ℤ‘0))
138136, 137sylib 218 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → ((𝑁𝑆) + 1) ∈ (ℤ‘0))
139 fzoss1 13743 . . . . . . . . . . 11 (((𝑁𝑆) + 1) ∈ (ℤ‘0) → (((𝑁𝑆) + 1)..^𝑁) ⊆ (0..^𝑁))
1402, 138, 1393syl 18 . . . . . . . . . 10 (𝜑 → (((𝑁𝑆) + 1)..^𝑁) ⊆ (0..^𝑁))
141140sselda 4008 . . . . . . . . 9 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑗 ∈ (0..^𝑁))
142 crctcshwlkn0lem.n . . . . . . . . . 10 𝑁 = (♯‘𝐹)
143142oveq2i 7459 . . . . . . . . 9 (0..^𝑁) = (0..^(♯‘𝐹))
144141, 143eleqtrdi 2854 . . . . . . . 8 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → 𝑗 ∈ (0..^(♯‘𝐹)))
145 cshwidxmod 14851 . . . . . . . 8 ((𝐹 ∈ Word 𝐴𝑆 ∈ ℤ ∧ 𝑗 ∈ (0..^(♯‘𝐹))) → ((𝐹 cyclShift 𝑆)‘𝑗) = (𝐹‘((𝑗 + 𝑆) mod (♯‘𝐹))))
146120, 122, 144, 145syl3anc 1371 . . . . . . 7 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝐹 cyclShift 𝑆)‘𝑗) = (𝐹‘((𝑗 + 𝑆) mod (♯‘𝐹))))
147142eqcomi 2749 . . . . . . . . . 10 (♯‘𝐹) = 𝑁
148147oveq2i 7459 . . . . . . . . 9 ((𝑗 + 𝑆) mod (♯‘𝐹)) = ((𝑗 + 𝑆) mod 𝑁)
149 eluzelre 12914 . . . . . . . . . . . . . . . . . . 19 (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) → 𝑗 ∈ ℝ)
1501493ad2ant1 1133 . . . . . . . . . . . . . . . . . 18 ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁) → 𝑗 ∈ ℝ)
151150adantl 481 . . . . . . . . . . . . . . . . 17 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑗 ∈ ℝ)
152273ad2ant1 1133 . . . . . . . . . . . . . . . . . 18 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑆 ∈ ℝ)
153152adantr 480 . . . . . . . . . . . . . . . . 17 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑆 ∈ ℝ)
154151, 153readdcld 11319 . . . . . . . . . . . . . . . 16 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → (𝑗 + 𝑆) ∈ ℝ)
155 nnrp 13068 . . . . . . . . . . . . . . . . . 18 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ+)
1561553ad2ant2 1134 . . . . . . . . . . . . . . . . 17 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ∈ ℝ+)
157156adantr 480 . . . . . . . . . . . . . . . 16 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑁 ∈ ℝ+)
15850impcom 407 . . . . . . . . . . . . . . . . 17 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑁 ≤ (𝑗 + 𝑆))
159157rpred 13099 . . . . . . . . . . . . . . . . . 18 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑁 ∈ ℝ)
160 simpr3 1196 . . . . . . . . . . . . . . . . . 18 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑗 < 𝑁)
161 simpl3 1193 . . . . . . . . . . . . . . . . . 18 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → 𝑆 < 𝑁)
162151, 153, 159, 160, 161lt2addmuld 12543 . . . . . . . . . . . . . . . . 17 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → (𝑗 + 𝑆) < (2 · 𝑁))
163158, 162jca 511 . . . . . . . . . . . . . . . 16 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁)))
164154, 157, 163jca31 514 . . . . . . . . . . . . . . 15 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) ∧ (𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁)) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁))))
165164ex 412 . . . . . . . . . . . . . 14 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑗 ∈ (ℤ‘((𝑁𝑆) + 1)) ∧ 𝑁 ∈ ℤ ∧ 𝑗 < 𝑁) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁)))))
16624, 165biimtrid 242 . . . . . . . . . . . . 13 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁)))))
16715, 166sylbi 217 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁)))))
1682, 167syl 17 . . . . . . . . . . 11 (𝜑 → (𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁)))))
169168imp 406 . . . . . . . . . 10 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁))))
170 2submod 13983 . . . . . . . . . 10 ((((𝑗 + 𝑆) ∈ ℝ ∧ 𝑁 ∈ ℝ+) ∧ (𝑁 ≤ (𝑗 + 𝑆) ∧ (𝑗 + 𝑆) < (2 · 𝑁))) → ((𝑗 + 𝑆) mod 𝑁) = ((𝑗 + 𝑆) − 𝑁))
171169, 170syl 17 . . . . . . . . 9 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝑗 + 𝑆) mod 𝑁) = ((𝑗 + 𝑆) − 𝑁))
172148, 171eqtrid 2792 . . . . . . . 8 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝑗 + 𝑆) mod (♯‘𝐹)) = ((𝑗 + 𝑆) − 𝑁))
173172fveq2d 6924 . . . . . . 7 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝐹‘((𝑗 + 𝑆) mod (♯‘𝐹))) = (𝐹‘((𝑗 + 𝑆) − 𝑁)))
174146, 173eqtrd 2780 . . . . . 6 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → ((𝐹 cyclShift 𝑆)‘𝑗) = (𝐹‘((𝑗 + 𝑆) − 𝑁)))
175118, 174eqtrid 2792 . . . . 5 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝐻𝑗) = (𝐹‘((𝑗 + 𝑆) − 𝑁)))
176175fveq2d 6924 . . . 4 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))
177 simp1 1136 . . . . . 6 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → (𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)))
178 simp2 1137 . . . . . 6 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)))
179177, 178eqeq12d 2756 . . . . 5 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → ((𝑄𝑗) = (𝑄‘(𝑗 + 1)) ↔ (𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))))
180 simp3 1138 . . . . . 6 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))
181177sneqd 4660 . . . . . 6 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → {(𝑄𝑗)} = {(𝑃‘((𝑗 + 𝑆) − 𝑁))})
182180, 181eqeq12d 2756 . . . . 5 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → ((𝐼‘(𝐻𝑗)) = {(𝑄𝑗)} ↔ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}))
183177, 178preq12d 4766 . . . . . 6 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → {(𝑄𝑗), (𝑄‘(𝑗 + 1))} = {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))})
184183, 180sseq12d 4042 . . . . 5 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → ({(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗)) ↔ {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))))
185179, 182, 184ifpbi123d 1079 . . . 4 (((𝑄𝑗) = (𝑃‘((𝑗 + 𝑆) − 𝑁)) ∧ (𝑄‘(𝑗 + 1)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)) ∧ (𝐼‘(𝐻𝑗)) = (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁)))) → (if-((𝑄𝑗) = (𝑄‘(𝑗 + 1)), (𝐼‘(𝐻𝑗)) = {(𝑄𝑗)}, {(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗))) ↔ if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
186113, 116, 176, 185syl3anc 1371 . . 3 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → (if-((𝑄𝑗) = (𝑄‘(𝑗 + 1)), (𝐼‘(𝐻𝑗)) = {(𝑄𝑗)}, {(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗))) ↔ if-((𝑃‘((𝑗 + 𝑆) − 𝑁)) = (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁)), (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))) = {(𝑃‘((𝑗 + 𝑆) − 𝑁))}, {(𝑃‘((𝑗 + 𝑆) − 𝑁)), (𝑃‘(((𝑗 + 1) + 𝑆) − 𝑁))} ⊆ (𝐼‘(𝐹‘((𝑗 + 𝑆) − 𝑁))))))
187109, 186mpbird 257 . 2 ((𝜑𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)) → if-((𝑄𝑗) = (𝑄‘(𝑗 + 1)), (𝐼‘(𝐻𝑗)) = {(𝑄𝑗)}, {(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗))))
188187ralrimiva 3152 1 (𝜑 → ∀𝑗 ∈ (((𝑁𝑆) + 1)..^𝑁)if-((𝑄𝑗) = (𝑄‘(𝑗 + 1)), (𝐼‘(𝐻𝑗)) = {(𝑄𝑗)}, {(𝑄𝑗), (𝑄‘(𝑗 + 1))} ⊆ (𝐼‘(𝐻𝑗))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  if-wif 1063  w3a 1087   = wceq 1537  wcel 2108  wral 3067  wss 3976  ifcif 4548  {csn 4648  {cpr 4650   class class class wbr 5166  cmpt 5249  cfv 6573  (class class class)co 7448  cc 11182  cr 11183  0cc0 11184  1c1 11185   + caddc 11187   · cmul 11189   < clt 11324  cle 11325  cmin 11520  cn 12293  2c2 12348  0cn0 12553  cz 12639  cuz 12903  +crp 13057  ...cfz 13567  ..^cfzo 13711   mod cmo 13920  chash 14379  Word cword 14562   cyclShift ccsh 14836
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1793  ax-4 1807  ax-5 1909  ax-6 1967  ax-7 2007  ax-8 2110  ax-9 2118  ax-10 2141  ax-11 2158  ax-12 2178  ax-ext 2711  ax-rep 5303  ax-sep 5317  ax-nul 5324  ax-pow 5383  ax-pr 5447  ax-un 7770  ax-cnex 11240  ax-resscn 11241  ax-1cn 11242  ax-icn 11243  ax-addcl 11244  ax-addrcl 11245  ax-mulcl 11246  ax-mulrcl 11247  ax-mulcom 11248  ax-addass 11249  ax-mulass 11250  ax-distr 11251  ax-i2m1 11252  ax-1ne0 11253  ax-1rid 11254  ax-rnegex 11255  ax-rrecex 11256  ax-cnre 11257  ax-pre-lttri 11258  ax-pre-lttrn 11259  ax-pre-ltadd 11260  ax-pre-mulgt0 11261  ax-pre-sup 11262
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 847  df-ifp 1064  df-3or 1088  df-3an 1089  df-tru 1540  df-fal 1550  df-ex 1778  df-nf 1782  df-sb 2065  df-mo 2543  df-eu 2572  df-clab 2718  df-cleq 2732  df-clel 2819  df-nfc 2895  df-ne 2947  df-nel 3053  df-ral 3068  df-rex 3077  df-rmo 3388  df-reu 3389  df-rab 3444  df-v 3490  df-sbc 3805  df-csb 3922  df-dif 3979  df-un 3981  df-in 3983  df-ss 3993  df-pss 3996  df-nul 4353  df-if 4549  df-pw 4624  df-sn 4649  df-pr 4651  df-op 4655  df-uni 4932  df-int 4971  df-iun 5017  df-br 5167  df-opab 5229  df-mpt 5250  df-tr 5284  df-id 5593  df-eprel 5599  df-po 5607  df-so 5608  df-fr 5652  df-we 5654  df-xp 5706  df-rel 5707  df-cnv 5708  df-co 5709  df-dm 5710  df-rn 5711  df-res 5712  df-ima 5713  df-pred 6332  df-ord 6398  df-on 6399  df-lim 6400  df-suc 6401  df-iota 6525  df-fun 6575  df-fn 6576  df-f 6577  df-f1 6578  df-fo 6579  df-f1o 6580  df-fv 6581  df-riota 7404  df-ov 7451  df-oprab 7452  df-mpo 7453  df-om 7904  df-1st 8030  df-2nd 8031  df-frecs 8322  df-wrecs 8353  df-recs 8427  df-rdg 8466  df-1o 8522  df-er 8763  df-en 9004  df-dom 9005  df-sdom 9006  df-fin 9007  df-sup 9511  df-inf 9512  df-card 10008  df-pnf 11326  df-mnf 11327  df-xr 11328  df-ltxr 11329  df-le 11330  df-sub 11522  df-neg 11523  df-div 11948  df-nn 12294  df-2 12356  df-n0 12554  df-z 12640  df-uz 12904  df-rp 13058  df-fz 13568  df-fzo 13712  df-fl 13843  df-mod 13921  df-hash 14380  df-word 14563  df-concat 14619  df-substr 14689  df-pfx 14719  df-csh 14837
This theorem is referenced by:  crctcshwlkn0lem7  29849
  Copyright terms: Public domain W3C validator