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

Theorem crctcshwlkn0lem6 29888
Description: Lemma for crctcshwlkn0 29894. (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))} ⊆ (𝐼‘(𝐹𝑖))))
crctcshwlkn0lem.e (𝜑 → (𝑃𝑁) = (𝑃‘0))
Assertion
Ref Expression
crctcshwlkn0lem6 ((𝜑𝐽 = (𝑁𝑆)) → if-((𝑄𝐽) = (𝑄‘(𝐽 + 1)), (𝐼‘(𝐻𝐽)) = {(𝑄𝐽)}, {(𝑄𝐽), (𝑄‘(𝐽 + 1))} ⊆ (𝐼‘(𝐻𝐽))))
Distinct variable groups:   𝑥,𝐽   𝑥,𝑁   𝑥,𝑃   𝑥,𝑆   𝜑,𝑥   𝑖,𝐹   𝑖,𝐼   𝑖,𝑁   𝑃,𝑖   𝑆,𝑖   𝜑,𝑖
Allowed substitution hints:   𝐴(𝑥,𝑖)   𝑄(𝑥,𝑖)   𝐹(𝑥)   𝐻(𝑥,𝑖)   𝐼(𝑥)   𝐽(𝑖)

Proof of Theorem crctcshwlkn0lem6
StepHypRef Expression
1 oveq1 7365 . . . . . . . . 9 (𝑖 = 0 → (𝑖 + 1) = (0 + 1))
2 0p1e1 12262 . . . . . . . . 9 (0 + 1) = 1
31, 2eqtrdi 2787 . . . . . . . 8 (𝑖 = 0 → (𝑖 + 1) = 1)
4 wkslem2 29682 . . . . . . . 8 ((𝑖 = 0 ∧ (𝑖 + 1) = 1) → (if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) ↔ if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
53, 4mpdan 687 . . . . . . 7 (𝑖 = 0 → (if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))) ↔ if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
6 crctcshwlkn0lem.p . . . . . . 7 (𝜑 → ∀𝑖 ∈ (0..^𝑁)if-((𝑃𝑖) = (𝑃‘(𝑖 + 1)), (𝐼‘(𝐹𝑖)) = {(𝑃𝑖)}, {(𝑃𝑖), (𝑃‘(𝑖 + 1))} ⊆ (𝐼‘(𝐹𝑖))))
7 crctcshwlkn0lem.s . . . . . . . . 9 (𝜑𝑆 ∈ (1..^𝑁))
8 elfzo1 13628 . . . . . . . . . 10 (𝑆 ∈ (1..^𝑁) ↔ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁))
9 simp2 1137 . . . . . . . . . 10 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ∈ ℕ)
108, 9sylbi 217 . . . . . . . . 9 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℕ)
117, 10syl 17 . . . . . . . 8 (𝜑𝑁 ∈ ℕ)
12 lbfzo0 13615 . . . . . . . 8 (0 ∈ (0..^𝑁) ↔ 𝑁 ∈ ℕ)
1311, 12sylibr 234 . . . . . . 7 (𝜑 → 0 ∈ (0..^𝑁))
145, 6, 13rspcdva 3577 . . . . . 6 (𝜑 → if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))))
15 crctcshwlkn0lem.e . . . . . . 7 (𝜑 → (𝑃𝑁) = (𝑃‘0))
16 eqeq1 2740 . . . . . . . 8 ((𝑃𝑁) = (𝑃‘0) → ((𝑃𝑁) = (𝑃‘1) ↔ (𝑃‘0) = (𝑃‘1)))
17 sneq 4590 . . . . . . . . 9 ((𝑃𝑁) = (𝑃‘0) → {(𝑃𝑁)} = {(𝑃‘0)})
1817eqeq2d 2747 . . . . . . . 8 ((𝑃𝑁) = (𝑃‘0) → ((𝐼‘(𝐹‘0)) = {(𝑃𝑁)} ↔ (𝐼‘(𝐹‘0)) = {(𝑃‘0)}))
19 preq1 4690 . . . . . . . . 9 ((𝑃𝑁) = (𝑃‘0) → {(𝑃𝑁), (𝑃‘1)} = {(𝑃‘0), (𝑃‘1)})
2019sseq1d 3965 . . . . . . . 8 ((𝑃𝑁) = (𝑃‘0) → ({(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)) ↔ {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))))
2116, 18, 20ifpbi123d 1078 . . . . . . 7 ((𝑃𝑁) = (𝑃‘0) → (if-((𝑃𝑁) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}, {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))) ↔ if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
2215, 21syl 17 . . . . . 6 (𝜑 → (if-((𝑃𝑁) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}, {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))) ↔ if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
2314, 22mpbird 257 . . . . 5 (𝜑 → if-((𝑃𝑁) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}, {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))))
24 nncn 12153 . . . . . . . . . 10 (𝑁 ∈ ℕ → 𝑁 ∈ ℂ)
25 nncn 12153 . . . . . . . . . 10 (𝑆 ∈ ℕ → 𝑆 ∈ ℂ)
26 npcan 11389 . . . . . . . . . 10 ((𝑁 ∈ ℂ ∧ 𝑆 ∈ ℂ) → ((𝑁𝑆) + 𝑆) = 𝑁)
2724, 25, 26syl2anr 597 . . . . . . . . 9 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → ((𝑁𝑆) + 𝑆) = 𝑁)
28 simpr 484 . . . . . . . . . 10 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) ∧ ((𝑁𝑆) + 𝑆) = 𝑁) → ((𝑁𝑆) + 𝑆) = 𝑁)
29 oveq1 7365 . . . . . . . . . . 11 (((𝑁𝑆) + 𝑆) = 𝑁 → (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = (𝑁 mod (♯‘𝐹)))
30 crctcshwlkn0lem.n . . . . . . . . . . . . . . 15 𝑁 = (♯‘𝐹)
3130eqcomi 2745 . . . . . . . . . . . . . 14 (♯‘𝐹) = 𝑁
3231a1i 11 . . . . . . . . . . . . 13 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (♯‘𝐹) = 𝑁)
3332oveq2d 7374 . . . . . . . . . . . 12 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod (♯‘𝐹)) = (𝑁 mod 𝑁))
34 nnrp 12917 . . . . . . . . . . . . . 14 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ+)
35 modid0 13817 . . . . . . . . . . . . . 14 (𝑁 ∈ ℝ+ → (𝑁 mod 𝑁) = 0)
3634, 35syl 17 . . . . . . . . . . . . 13 (𝑁 ∈ ℕ → (𝑁 mod 𝑁) = 0)
3736adantl 481 . . . . . . . . . . . 12 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod 𝑁) = 0)
3833, 37eqtrd 2771 . . . . . . . . . . 11 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod (♯‘𝐹)) = 0)
3929, 38sylan9eqr 2793 . . . . . . . . . 10 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) ∧ ((𝑁𝑆) + 𝑆) = 𝑁) → (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0)
40 simpl 482 . . . . . . . . . 10 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) ∧ ((𝑁𝑆) + 𝑆) = 𝑁) → (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ))
4128, 39, 403jca 1128 . . . . . . . . 9 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) ∧ ((𝑁𝑆) + 𝑆) = 𝑁) → (((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)))
4227, 41mpdan 687 . . . . . . . 8 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)))
43423adant3 1132 . . . . . . 7 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)))
448, 43sylbi 217 . . . . . 6 (𝑆 ∈ (1..^𝑁) → (((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)))
45 simp1 1136 . . . . . . . . 9 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ((𝑁𝑆) + 𝑆) = 𝑁)
4645fveq2d 6838 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃𝑁))
4746eqeq1d 2738 . . . . . . 7 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1) ↔ (𝑃𝑁) = (𝑃‘1)))
48 simp2 1137 . . . . . . . . . 10 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0)
4948fveq2d 6838 . . . . . . . . 9 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))) = (𝐹‘0))
5049fveq2d 6838 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = (𝐼‘(𝐹‘0)))
5146sneqd 4592 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → {(𝑃‘((𝑁𝑆) + 𝑆))} = {(𝑃𝑁)})
5250, 51eqeq12d 2752 . . . . . . 7 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ((𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))} ↔ (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}))
5346preq1d 4696 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} = {(𝑃𝑁), (𝑃‘1)})
5453, 50sseq12d 3967 . . . . . . 7 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ({(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) ↔ {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))))
5547, 52, 54ifpbi123d 1078 . . . . . 6 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (if-((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1), (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}, {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))) ↔ if-((𝑃𝑁) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}, {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
567, 44, 553syl 18 . . . . 5 (𝜑 → (if-((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1), (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}, {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))) ↔ if-((𝑃𝑁) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}, {(𝑃𝑁), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0)))))
5723, 56mpbird 257 . . . 4 (𝜑 → if-((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1), (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}, {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))))
58 nnsub 12189 . . . . . . . . . . 11 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 < 𝑁 ↔ (𝑁𝑆) ∈ ℕ))
5958biimp3a 1471 . . . . . . . . . 10 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑁𝑆) ∈ ℕ)
6059nnnn0d 12462 . . . . . . . . 9 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑁𝑆) ∈ ℕ0)
618, 60sylbi 217 . . . . . . . 8 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ ℕ0)
627, 61syl 17 . . . . . . 7 (𝜑 → (𝑁𝑆) ∈ ℕ0)
63 nn0fz0 13541 . . . . . . 7 ((𝑁𝑆) ∈ ℕ0 ↔ (𝑁𝑆) ∈ (0...(𝑁𝑆)))
6462, 63sylib 218 . . . . . 6 (𝜑 → (𝑁𝑆) ∈ (0...(𝑁𝑆)))
65 crctcshwlkn0lem.q . . . . . . 7 𝑄 = (𝑥 ∈ (0...𝑁) ↦ if(𝑥 ≤ (𝑁𝑆), (𝑃‘(𝑥 + 𝑆)), (𝑃‘((𝑥 + 𝑆) − 𝑁))))
667, 65crctcshwlkn0lem2 29884 . . . . . 6 ((𝜑 ∧ (𝑁𝑆) ∈ (0...(𝑁𝑆))) → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
6764, 66mpdan 687 . . . . 5 (𝜑 → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
68 elfzoel2 13574 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℤ)
69 elfzoelz 13575 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ ℤ)
7068, 69zsubcld 12601 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ ℤ)
7170peano2zd 12599 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → ((𝑁𝑆) + 1) ∈ ℤ)
72 nnre 12152 . . . . . . . . . . . . . . . 16 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ)
7372anim1i 615 . . . . . . . . . . . . . . 15 ((𝑁 ∈ ℕ ∧ 𝑆 ∈ ℕ) → (𝑁 ∈ ℝ ∧ 𝑆 ∈ ℕ))
7473ancoms 458 . . . . . . . . . . . . . 14 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 ∈ ℝ ∧ 𝑆 ∈ ℕ))
75 crctcshwlkn0lem1 29883 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℝ ∧ 𝑆 ∈ ℕ) → ((𝑁𝑆) + 1) ≤ 𝑁)
7674, 75syl 17 . . . . . . . . . . . . 13 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → ((𝑁𝑆) + 1) ≤ 𝑁)
77763adant3 1132 . . . . . . . . . . . 12 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((𝑁𝑆) + 1) ≤ 𝑁)
788, 77sylbi 217 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → ((𝑁𝑆) + 1) ≤ 𝑁)
7971, 68, 783jca 1128 . . . . . . . . . 10 (𝑆 ∈ (1..^𝑁) → (((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑁))
807, 79syl 17 . . . . . . . . 9 (𝜑 → (((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑁))
81 eluz2 12757 . . . . . . . . 9 (𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)) ↔ (((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑁))
8280, 81sylibr 234 . . . . . . . 8 (𝜑𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)))
83 eluzfz1 13447 . . . . . . . 8 (𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)) → ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁))
8482, 83syl 17 . . . . . . 7 (𝜑 → ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁))
857, 65crctcshwlkn0lem3 29885 . . . . . . 7 ((𝜑 ∧ ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁)) → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)))
8684, 85mpdan 687 . . . . . 6 (𝜑 → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)))
87 subcl 11379 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℂ ∧ 𝑆 ∈ ℂ) → (𝑁𝑆) ∈ ℂ)
8887ancoms 458 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → (𝑁𝑆) ∈ ℂ)
89 ax-1cn 11084 . . . . . . . . . . . . 13 1 ∈ ℂ
90 pncan2 11387 . . . . . . . . . . . . . 14 (((𝑁𝑆) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝑁𝑆) + 1) − (𝑁𝑆)) = 1)
9190eqcomd 2742 . . . . . . . . . . . . 13 (((𝑁𝑆) ∈ ℂ ∧ 1 ∈ ℂ) → 1 = (((𝑁𝑆) + 1) − (𝑁𝑆)))
9288, 89, 91sylancl 586 . . . . . . . . . . . 12 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 1 = (((𝑁𝑆) + 1) − (𝑁𝑆)))
93 peano2cn 11305 . . . . . . . . . . . . . 14 ((𝑁𝑆) ∈ ℂ → ((𝑁𝑆) + 1) ∈ ℂ)
9488, 93syl 17 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → ((𝑁𝑆) + 1) ∈ ℂ)
95 simpr 484 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 𝑁 ∈ ℂ)
96 simpl 482 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 𝑆 ∈ ℂ)
9794, 95, 96subsub3d 11522 . . . . . . . . . . . 12 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → (((𝑁𝑆) + 1) − (𝑁𝑆)) = ((((𝑁𝑆) + 1) + 𝑆) − 𝑁))
9892, 97eqtr2d 2772 . . . . . . . . . . 11 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → ((((𝑁𝑆) + 1) + 𝑆) − 𝑁) = 1)
9925, 24, 98syl2an 596 . . . . . . . . . 10 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → ((((𝑁𝑆) + 1) + 𝑆) − 𝑁) = 1)
100993adant3 1132 . . . . . . . . 9 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → ((((𝑁𝑆) + 1) + 𝑆) − 𝑁) = 1)
1018, 100sylbi 217 . . . . . . . 8 (𝑆 ∈ (1..^𝑁) → ((((𝑁𝑆) + 1) + 𝑆) − 𝑁) = 1)
1027, 101syl 17 . . . . . . 7 (𝜑 → ((((𝑁𝑆) + 1) + 𝑆) − 𝑁) = 1)
103102fveq2d 6838 . . . . . 6 (𝜑 → (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)) = (𝑃‘1))
10486, 103eqtrd 2771 . . . . 5 (𝜑 → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1))
105 crctcshwlkn0lem.h . . . . . . 7 𝐻 = (𝐹 cyclShift 𝑆)
106105fveq1i 6835 . . . . . 6 (𝐻‘(𝑁𝑆)) = ((𝐹 cyclShift 𝑆)‘(𝑁𝑆))
107 crctcshwlkn0lem.f . . . . . . . . 9 (𝜑𝐹 ∈ Word 𝐴)
108107adantr 480 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → 𝐹 ∈ Word 𝐴)
10969adantl 481 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → 𝑆 ∈ ℤ)
110 elfzofz 13591 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ (1...𝑁))
111 ubmelfzo 13646 . . . . . . . . . . 11 (𝑆 ∈ (1...𝑁) → (𝑁𝑆) ∈ (0..^𝑁))
112110, 111syl 17 . . . . . . . . . 10 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ (0..^𝑁))
113112adantl 481 . . . . . . . . 9 ((𝜑𝑆 ∈ (1..^𝑁)) → (𝑁𝑆) ∈ (0..^𝑁))
11431oveq2i 7369 . . . . . . . . 9 (0..^(♯‘𝐹)) = (0..^𝑁)
115113, 114eleqtrrdi 2847 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → (𝑁𝑆) ∈ (0..^(♯‘𝐹)))
116 cshwidxmod 14726 . . . . . . . 8 ((𝐹 ∈ Word 𝐴𝑆 ∈ ℤ ∧ (𝑁𝑆) ∈ (0..^(♯‘𝐹))) → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
117108, 109, 115, 116syl3anc 1373 . . . . . . 7 ((𝜑𝑆 ∈ (1..^𝑁)) → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
1187, 117mpdan 687 . . . . . 6 (𝜑 → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
119106, 118eqtrid 2783 . . . . 5 (𝜑 → (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
120 simp1 1136 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
121 simp2 1137 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1))
122120, 121eqeq12d 2752 . . . . . 6 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → ((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)) ↔ (𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1)))
123 simp3 1138 . . . . . . . 8 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
124123fveq2d 6838 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝐼‘(𝐻‘(𝑁𝑆))) = (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))))
125120sneqd 4592 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → {(𝑄‘(𝑁𝑆))} = {(𝑃‘((𝑁𝑆) + 𝑆))})
126124, 125eqeq12d 2752 . . . . . 6 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → ((𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))} ↔ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}))
127120, 121preq12d 4698 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} = {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)})
128127, 124sseq12d 3967 . . . . . 6 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → ({(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆))) ↔ {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))))
129122, 126, 128ifpbi123d 1078 . . . . 5 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆)))) ↔ if-((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1), (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}, {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))))))
13067, 104, 119, 129syl3anc 1373 . . . 4 (𝜑 → (if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆)))) ↔ if-((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1), (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}, {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))))))
13157, 130mpbird 257 . . 3 (𝜑 → if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆)))))
132131adantr 480 . 2 ((𝜑𝐽 = (𝑁𝑆)) → if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆)))))
133 wkslem1 29681 . . 3 (𝐽 = (𝑁𝑆) → (if-((𝑄𝐽) = (𝑄‘(𝐽 + 1)), (𝐼‘(𝐻𝐽)) = {(𝑄𝐽)}, {(𝑄𝐽), (𝑄‘(𝐽 + 1))} ⊆ (𝐼‘(𝐻𝐽))) ↔ if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆))))))
134133adantl 481 . 2 ((𝜑𝐽 = (𝑁𝑆)) → (if-((𝑄𝐽) = (𝑄‘(𝐽 + 1)), (𝐼‘(𝐻𝐽)) = {(𝑄𝐽)}, {(𝑄𝐽), (𝑄‘(𝐽 + 1))} ⊆ (𝐼‘(𝐻𝐽))) ↔ if-((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)), (𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))}, {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} ⊆ (𝐼‘(𝐻‘(𝑁𝑆))))))
135132, 134mpbird 257 1 ((𝜑𝐽 = (𝑁𝑆)) → if-((𝑄𝐽) = (𝑄‘(𝐽 + 1)), (𝐼‘(𝐻𝐽)) = {(𝑄𝐽)}, {(𝑄𝐽), (𝑄‘(𝐽 + 1))} ⊆ (𝐼‘(𝐻𝐽))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  if-wif 1062  w3a 1086   = wceq 1541  wcel 2113  wral 3051  wss 3901  ifcif 4479  {csn 4580  {cpr 4582   class class class wbr 5098  cmpt 5179  cfv 6492  (class class class)co 7358  cc 11024  cr 11025  0cc0 11026  1c1 11027   + caddc 11029   < clt 11166  cle 11167  cmin 11364  cn 12145  0cn0 12401  cz 12488  cuz 12751  +crp 12905  ...cfz 13423  ..^cfzo 13570   mod cmo 13789  chash 14253  Word cword 14436   cyclShift ccsh 14711
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1968  ax-7 2009  ax-8 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2184  ax-ext 2708  ax-rep 5224  ax-sep 5241  ax-nul 5251  ax-pow 5310  ax-pr 5377  ax-un 7680  ax-cnex 11082  ax-resscn 11083  ax-1cn 11084  ax-icn 11085  ax-addcl 11086  ax-addrcl 11087  ax-mulcl 11088  ax-mulrcl 11089  ax-mulcom 11090  ax-addass 11091  ax-mulass 11092  ax-distr 11093  ax-i2m1 11094  ax-1ne0 11095  ax-1rid 11096  ax-rnegex 11097  ax-rrecex 11098  ax-cnre 11099  ax-pre-lttri 11100  ax-pre-lttrn 11101  ax-pre-ltadd 11102  ax-pre-mulgt0 11103  ax-pre-sup 11104
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-ifp 1063  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2539  df-eu 2569  df-clab 2715  df-cleq 2728  df-clel 2811  df-nfc 2885  df-ne 2933  df-nel 3037  df-ral 3052  df-rex 3061  df-rmo 3350  df-reu 3351  df-rab 3400  df-v 3442  df-sbc 3741  df-csb 3850  df-dif 3904  df-un 3906  df-in 3908  df-ss 3918  df-pss 3921  df-nul 4286  df-if 4480  df-pw 4556  df-sn 4581  df-pr 4583  df-op 4587  df-uni 4864  df-int 4903  df-iun 4948  df-br 5099  df-opab 5161  df-mpt 5180  df-tr 5206  df-id 5519  df-eprel 5524  df-po 5532  df-so 5533  df-fr 5577  df-we 5579  df-xp 5630  df-rel 5631  df-cnv 5632  df-co 5633  df-dm 5634  df-rn 5635  df-res 5636  df-ima 5637  df-pred 6259  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-f1o 6499  df-fv 6500  df-riota 7315  df-ov 7361  df-oprab 7362  df-mpo 7363  df-om 7809  df-1st 7933  df-2nd 7934  df-frecs 8223  df-wrecs 8254  df-recs 8303  df-rdg 8341  df-1o 8397  df-er 8635  df-en 8884  df-dom 8885  df-sdom 8886  df-fin 8887  df-sup 9345  df-inf 9346  df-card 9851  df-pnf 11168  df-mnf 11169  df-xr 11170  df-ltxr 11171  df-le 11172  df-sub 11366  df-neg 11367  df-div 11795  df-nn 12146  df-2 12208  df-n0 12402  df-z 12489  df-uz 12752  df-rp 12906  df-fz 13424  df-fzo 13571  df-fl 13712  df-mod 13790  df-hash 14254  df-word 14437  df-concat 14494  df-substr 14565  df-pfx 14595  df-csh 14712
This theorem is referenced by:  crctcshwlkn0lem7  29889
  Copyright terms: Public domain W3C validator