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

Theorem crctcshwlkn0lem6 29718
Description: Lemma for crctcshwlkn0 29724. (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 7376 . . . . . . . . 9 (𝑖 = 0 → (𝑖 + 1) = (0 + 1))
2 0p1e1 12279 . . . . . . . . 9 (0 + 1) = 1
31, 2eqtrdi 2780 . . . . . . . 8 (𝑖 = 0 → (𝑖 + 1) = 1)
4 wkslem2 29512 . . . . . . . 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 13649 . . . . . . . . . 10 (𝑆 ∈ (1..^𝑁) ↔ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁))
9 simp2 1137 . . . . . . . . . 10 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → 𝑁 ∈ ℕ)
108, 9sylbi 217 . . . . . . . . 9 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℕ)
117, 10syl 17 . . . . . . . 8 (𝜑𝑁 ∈ ℕ)
12 lbfzo0 13636 . . . . . . . 8 (0 ∈ (0..^𝑁) ↔ 𝑁 ∈ ℕ)
1311, 12sylibr 234 . . . . . . 7 (𝜑 → 0 ∈ (0..^𝑁))
145, 6, 13rspcdva 3586 . . . . . 6 (𝜑 → if-((𝑃‘0) = (𝑃‘1), (𝐼‘(𝐹‘0)) = {(𝑃‘0)}, {(𝑃‘0), (𝑃‘1)} ⊆ (𝐼‘(𝐹‘0))))
15 crctcshwlkn0lem.e . . . . . . 7 (𝜑 → (𝑃𝑁) = (𝑃‘0))
16 eqeq1 2733 . . . . . . . 8 ((𝑃𝑁) = (𝑃‘0) → ((𝑃𝑁) = (𝑃‘1) ↔ (𝑃‘0) = (𝑃‘1)))
17 sneq 4595 . . . . . . . . 9 ((𝑃𝑁) = (𝑃‘0) → {(𝑃𝑁)} = {(𝑃‘0)})
1817eqeq2d 2740 . . . . . . . 8 ((𝑃𝑁) = (𝑃‘0) → ((𝐼‘(𝐹‘0)) = {(𝑃𝑁)} ↔ (𝐼‘(𝐹‘0)) = {(𝑃‘0)}))
19 preq1 4693 . . . . . . . . 9 ((𝑃𝑁) = (𝑃‘0) → {(𝑃𝑁), (𝑃‘1)} = {(𝑃‘0), (𝑃‘1)})
2019sseq1d 3975 . . . . . . . 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 12170 . . . . . . . . . 10 (𝑁 ∈ ℕ → 𝑁 ∈ ℂ)
25 nncn 12170 . . . . . . . . . 10 (𝑆 ∈ ℕ → 𝑆 ∈ ℂ)
26 npcan 11406 . . . . . . . . . 10 ((𝑁 ∈ ℂ ∧ 𝑆 ∈ ℂ) → ((𝑁𝑆) + 𝑆) = 𝑁)
2724, 25, 26syl2anr 597 . . . . . . . . 9 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → ((𝑁𝑆) + 𝑆) = 𝑁)
28 simpr 484 . . . . . . . . . 10 (((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) ∧ ((𝑁𝑆) + 𝑆) = 𝑁) → ((𝑁𝑆) + 𝑆) = 𝑁)
29 oveq1 7376 . . . . . . . . . . 11 (((𝑁𝑆) + 𝑆) = 𝑁 → (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = (𝑁 mod (♯‘𝐹)))
30 crctcshwlkn0lem.n . . . . . . . . . . . . . . 15 𝑁 = (♯‘𝐹)
3130eqcomi 2738 . . . . . . . . . . . . . 14 (♯‘𝐹) = 𝑁
3231a1i 11 . . . . . . . . . . . . 13 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (♯‘𝐹) = 𝑁)
3332oveq2d 7385 . . . . . . . . . . . 12 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod (♯‘𝐹)) = (𝑁 mod 𝑁))
34 nnrp 12939 . . . . . . . . . . . . . 14 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ+)
35 modid0 13835 . . . . . . . . . . . . . 14 (𝑁 ∈ ℝ+ → (𝑁 mod 𝑁) = 0)
3634, 35syl 17 . . . . . . . . . . . . 13 (𝑁 ∈ ℕ → (𝑁 mod 𝑁) = 0)
3736adantl 481 . . . . . . . . . . . 12 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod 𝑁) = 0)
3833, 37eqtrd 2764 . . . . . . . . . . 11 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 mod (♯‘𝐹)) = 0)
3929, 38sylan9eqr 2786 . . . . . . . . . 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 6844 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃𝑁))
4746eqeq1d 2731 . . . . . . 7 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ((𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1) ↔ (𝑃𝑁) = (𝑃‘1)))
48 simp2 1137 . . . . . . . . . 10 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0)
4948fveq2d 6844 . . . . . . . . 9 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))) = (𝐹‘0))
5049fveq2d 6844 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = (𝐼‘(𝐹‘0)))
5146sneqd 4597 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → {(𝑃‘((𝑁𝑆) + 𝑆))} = {(𝑃𝑁)})
5250, 51eqeq12d 2745 . . . . . . 7 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → ((𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))} ↔ (𝐼‘(𝐹‘0)) = {(𝑃𝑁)}))
5346preq1d 4699 . . . . . . . 8 ((((𝑁𝑆) + 𝑆) = 𝑁 ∧ (((𝑁𝑆) + 𝑆) mod (♯‘𝐹)) = 0 ∧ (𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ)) → {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)} = {(𝑃𝑁), (𝑃‘1)})
5453, 50sseq12d 3977 . . . . . . 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 12206 . . . . . . . . . . 11 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑆 < 𝑁 ↔ (𝑁𝑆) ∈ ℕ))
5958biimp3a 1471 . . . . . . . . . 10 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑁𝑆) ∈ ℕ)
6059nnnn0d 12479 . . . . . . . . 9 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 𝑆 < 𝑁) → (𝑁𝑆) ∈ ℕ0)
618, 60sylbi 217 . . . . . . . 8 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ ℕ0)
627, 61syl 17 . . . . . . 7 (𝜑 → (𝑁𝑆) ∈ ℕ0)
63 nn0fz0 13562 . . . . . . 7 ((𝑁𝑆) ∈ ℕ0 ↔ (𝑁𝑆) ∈ (0...(𝑁𝑆)))
6462, 63sylib 218 . . . . . 6 (𝜑 → (𝑁𝑆) ∈ (0...(𝑁𝑆)))
65 crctcshwlkn0lem.q . . . . . . 7 𝑄 = (𝑥 ∈ (0...𝑁) ↦ if(𝑥 ≤ (𝑁𝑆), (𝑃‘(𝑥 + 𝑆)), (𝑃‘((𝑥 + 𝑆) − 𝑁))))
667, 65crctcshwlkn0lem2 29714 . . . . . 6 ((𝜑 ∧ (𝑁𝑆) ∈ (0...(𝑁𝑆))) → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
6764, 66mpdan 687 . . . . 5 (𝜑 → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
68 elfzoel2 13595 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → 𝑁 ∈ ℤ)
69 elfzoelz 13596 . . . . . . . . . . . . 13 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ ℤ)
7068, 69zsubcld 12619 . . . . . . . . . . . 12 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ ℤ)
7170peano2zd 12617 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → ((𝑁𝑆) + 1) ∈ ℤ)
72 nnre 12169 . . . . . . . . . . . . . . . 16 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ)
7372anim1i 615 . . . . . . . . . . . . . . 15 ((𝑁 ∈ ℕ ∧ 𝑆 ∈ ℕ) → (𝑁 ∈ ℝ ∧ 𝑆 ∈ ℕ))
7473ancoms 458 . . . . . . . . . . . . . 14 ((𝑆 ∈ ℕ ∧ 𝑁 ∈ ℕ) → (𝑁 ∈ ℝ ∧ 𝑆 ∈ ℕ))
75 crctcshwlkn0lem1 29713 . . . . . . . . . . . . . 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 12775 . . . . . . . . 9 (𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)) ↔ (((𝑁𝑆) + 1) ∈ ℤ ∧ 𝑁 ∈ ℤ ∧ ((𝑁𝑆) + 1) ≤ 𝑁))
8280, 81sylibr 234 . . . . . . . 8 (𝜑𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)))
83 eluzfz1 13468 . . . . . . . 8 (𝑁 ∈ (ℤ‘((𝑁𝑆) + 1)) → ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁))
8482, 83syl 17 . . . . . . 7 (𝜑 → ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁))
857, 65crctcshwlkn0lem3 29715 . . . . . . 7 ((𝜑 ∧ ((𝑁𝑆) + 1) ∈ (((𝑁𝑆) + 1)...𝑁)) → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)))
8684, 85mpdan 687 . . . . . 6 (𝜑 → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)))
87 subcl 11396 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℂ ∧ 𝑆 ∈ ℂ) → (𝑁𝑆) ∈ ℂ)
8887ancoms 458 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → (𝑁𝑆) ∈ ℂ)
89 ax-1cn 11102 . . . . . . . . . . . . 13 1 ∈ ℂ
90 pncan2 11404 . . . . . . . . . . . . . 14 (((𝑁𝑆) ∈ ℂ ∧ 1 ∈ ℂ) → (((𝑁𝑆) + 1) − (𝑁𝑆)) = 1)
9190eqcomd 2735 . . . . . . . . . . . . 13 (((𝑁𝑆) ∈ ℂ ∧ 1 ∈ ℂ) → 1 = (((𝑁𝑆) + 1) − (𝑁𝑆)))
9288, 89, 91sylancl 586 . . . . . . . . . . . 12 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 1 = (((𝑁𝑆) + 1) − (𝑁𝑆)))
93 peano2cn 11322 . . . . . . . . . . . . . 14 ((𝑁𝑆) ∈ ℂ → ((𝑁𝑆) + 1) ∈ ℂ)
9488, 93syl 17 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → ((𝑁𝑆) + 1) ∈ ℂ)
95 simpr 484 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 𝑁 ∈ ℂ)
96 simpl 482 . . . . . . . . . . . . 13 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → 𝑆 ∈ ℂ)
9794, 95, 96subsub3d 11539 . . . . . . . . . . . 12 ((𝑆 ∈ ℂ ∧ 𝑁 ∈ ℂ) → (((𝑁𝑆) + 1) − (𝑁𝑆)) = ((((𝑁𝑆) + 1) + 𝑆) − 𝑁))
9892, 97eqtr2d 2765 . . . . . . . . . . 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 6844 . . . . . 6 (𝜑 → (𝑃‘((((𝑁𝑆) + 1) + 𝑆) − 𝑁)) = (𝑃‘1))
10486, 103eqtrd 2764 . . . . 5 (𝜑 → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1))
105 crctcshwlkn0lem.h . . . . . . 7 𝐻 = (𝐹 cyclShift 𝑆)
106105fveq1i 6841 . . . . . 6 (𝐻‘(𝑁𝑆)) = ((𝐹 cyclShift 𝑆)‘(𝑁𝑆))
107 crctcshwlkn0lem.f . . . . . . . . 9 (𝜑𝐹 ∈ Word 𝐴)
108107adantr 480 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → 𝐹 ∈ Word 𝐴)
10969adantl 481 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → 𝑆 ∈ ℤ)
110 elfzofz 13612 . . . . . . . . . . 11 (𝑆 ∈ (1..^𝑁) → 𝑆 ∈ (1...𝑁))
111 ubmelfzo 13667 . . . . . . . . . . 11 (𝑆 ∈ (1...𝑁) → (𝑁𝑆) ∈ (0..^𝑁))
112110, 111syl 17 . . . . . . . . . 10 (𝑆 ∈ (1..^𝑁) → (𝑁𝑆) ∈ (0..^𝑁))
113112adantl 481 . . . . . . . . 9 ((𝜑𝑆 ∈ (1..^𝑁)) → (𝑁𝑆) ∈ (0..^𝑁))
11431oveq2i 7380 . . . . . . . . 9 (0..^(♯‘𝐹)) = (0..^𝑁)
115113, 114eleqtrrdi 2839 . . . . . . . 8 ((𝜑𝑆 ∈ (1..^𝑁)) → (𝑁𝑆) ∈ (0..^(♯‘𝐹)))
116 cshwidxmod 14744 . . . . . . . 8 ((𝐹 ∈ Word 𝐴𝑆 ∈ ℤ ∧ (𝑁𝑆) ∈ (0..^(♯‘𝐹))) → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
117108, 109, 115, 116syl3anc 1373 . . . . . . 7 ((𝜑𝑆 ∈ (1..^𝑁)) → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
1187, 117mpdan 687 . . . . . 6 (𝜑 → ((𝐹 cyclShift 𝑆)‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
119106, 118eqtrid 2776 . . . . 5 (𝜑 → (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
120 simp1 1136 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)))
121 simp2 1137 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1))
122120, 121eqeq12d 2745 . . . . . 6 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → ((𝑄‘(𝑁𝑆)) = (𝑄‘((𝑁𝑆) + 1)) ↔ (𝑃‘((𝑁𝑆) + 𝑆)) = (𝑃‘1)))
123 simp3 1138 . . . . . . . 8 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹))))
124123fveq2d 6844 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → (𝐼‘(𝐻‘(𝑁𝑆))) = (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))))
125120sneqd 4597 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → {(𝑄‘(𝑁𝑆))} = {(𝑃‘((𝑁𝑆) + 𝑆))})
126124, 125eqeq12d 2745 . . . . . 6 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → ((𝐼‘(𝐻‘(𝑁𝑆))) = {(𝑄‘(𝑁𝑆))} ↔ (𝐼‘(𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) = {(𝑃‘((𝑁𝑆) + 𝑆))}))
127120, 121preq12d 4701 . . . . . . 7 (((𝑄‘(𝑁𝑆)) = (𝑃‘((𝑁𝑆) + 𝑆)) ∧ (𝑄‘((𝑁𝑆) + 1)) = (𝑃‘1) ∧ (𝐻‘(𝑁𝑆)) = (𝐹‘(((𝑁𝑆) + 𝑆) mod (♯‘𝐹)))) → {(𝑄‘(𝑁𝑆)), (𝑄‘((𝑁𝑆) + 1))} = {(𝑃‘((𝑁𝑆) + 𝑆)), (𝑃‘1)})
128127, 124sseq12d 3977 . . . . . 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 29511 . . 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 1540  wcel 2109  wral 3044  wss 3911  ifcif 4484  {csn 4585  {cpr 4587   class class class wbr 5102  cmpt 5183  cfv 6499  (class class class)co 7369  cc 11042  cr 11043  0cc0 11044  1c1 11045   + caddc 11047   < clt 11184  cle 11185  cmin 11381  cn 12162  0cn0 12418  cz 12505  cuz 12769  +crp 12927  ...cfz 13444  ..^cfzo 13591   mod cmo 13807  chash 14271  Word cword 14454   cyclShift ccsh 14729
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2701  ax-rep 5229  ax-sep 5246  ax-nul 5256  ax-pow 5315  ax-pr 5382  ax-un 7691  ax-cnex 11100  ax-resscn 11101  ax-1cn 11102  ax-icn 11103  ax-addcl 11104  ax-addrcl 11105  ax-mulcl 11106  ax-mulrcl 11107  ax-mulcom 11108  ax-addass 11109  ax-mulass 11110  ax-distr 11111  ax-i2m1 11112  ax-1ne0 11113  ax-1rid 11114  ax-rnegex 11115  ax-rrecex 11116  ax-cnre 11117  ax-pre-lttri 11118  ax-pre-lttrn 11119  ax-pre-ltadd 11120  ax-pre-mulgt0 11121  ax-pre-sup 11122
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 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2533  df-eu 2562  df-clab 2708  df-cleq 2721  df-clel 2803  df-nfc 2878  df-ne 2926  df-nel 3030  df-ral 3045  df-rex 3054  df-rmo 3351  df-reu 3352  df-rab 3403  df-v 3446  df-sbc 3751  df-csb 3860  df-dif 3914  df-un 3916  df-in 3918  df-ss 3928  df-pss 3931  df-nul 4293  df-if 4485  df-pw 4561  df-sn 4586  df-pr 4588  df-op 4592  df-uni 4868  df-int 4907  df-iun 4953  df-br 5103  df-opab 5165  df-mpt 5184  df-tr 5210  df-id 5526  df-eprel 5531  df-po 5539  df-so 5540  df-fr 5584  df-we 5586  df-xp 5637  df-rel 5638  df-cnv 5639  df-co 5640  df-dm 5641  df-rn 5642  df-res 5643  df-ima 5644  df-pred 6262  df-ord 6323  df-on 6324  df-lim 6325  df-suc 6326  df-iota 6452  df-fun 6501  df-fn 6502  df-f 6503  df-f1 6504  df-fo 6505  df-f1o 6506  df-fv 6507  df-riota 7326  df-ov 7372  df-oprab 7373  df-mpo 7374  df-om 7823  df-1st 7947  df-2nd 7948  df-frecs 8237  df-wrecs 8268  df-recs 8317  df-rdg 8355  df-1o 8411  df-er 8648  df-en 8896  df-dom 8897  df-sdom 8898  df-fin 8899  df-sup 9369  df-inf 9370  df-card 9868  df-pnf 11186  df-mnf 11187  df-xr 11188  df-ltxr 11189  df-le 11190  df-sub 11383  df-neg 11384  df-div 11812  df-nn 12163  df-2 12225  df-n0 12419  df-z 12506  df-uz 12770  df-rp 12928  df-fz 13445  df-fzo 13592  df-fl 13730  df-mod 13808  df-hash 14272  df-word 14455  df-concat 14512  df-substr 14582  df-pfx 14612  df-csh 14730
This theorem is referenced by:  crctcshwlkn0lem7  29719
  Copyright terms: Public domain W3C validator