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

Theorem eleclclwwlknlem2 30149
Description: Lemma 2 for eleclclwwlkn 30164. (Contributed by Alexander van der Vekens, 11-May-2018.) (Revised by AV, 30-Apr-2021.)
Hypothesis
Ref Expression
erclwwlkn1.w 𝑊 = (𝑁 ClWWalksN 𝐺)
Assertion
Ref Expression
eleclclwwlknlem2 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚) ↔ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
Distinct variable groups:   𝑚,𝑛,𝐺   𝑚,𝑁,𝑛   𝑚,𝑋,𝑛   𝑚,𝑌,𝑛   𝑘,𝑚,𝑛   𝑥,𝑚,𝑛
Allowed substitution hints:   𝐺(𝑥,𝑘)   𝑁(𝑥,𝑘)   𝑊(𝑥,𝑘,𝑚,𝑛)   𝑋(𝑥,𝑘)   𝑌(𝑥,𝑘)

Proof of Theorem eleclclwwlknlem2
StepHypRef Expression
1 simpl 483 . . . . 5 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → 𝑘 ∈ (0...𝑁))
21anim1i 621 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)))
32adantr 481 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → (𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)))
4 simpr 485 . . . . 5 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → 𝑋 = (𝑥 cyclShift 𝑘))
54adantr 481 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → 𝑋 = (𝑥 cyclShift 𝑘))
65anim1i 621 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → (𝑋 = (𝑥 cyclShift 𝑘) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)))
7 erclwwlkn1.w . . . 4 𝑊 = (𝑁 ClWWalksN 𝐺)
87eleclclwwlknlem1 30148 . . 3 ((𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)) → ((𝑋 = (𝑥 cyclShift 𝑘) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
93, 6, 8sylc 65 . 2 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛))
10 eqid 2739 . . . . . . . . . . . 12 (Vtx‘𝐺) = (Vtx‘𝐺)
1110clwwlknbp 30123 . . . . . . . . . . 11 (𝑥 ∈ (𝑁 ClWWalksN 𝐺) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁))
1211, 7eleq2s 2857 . . . . . . . . . 10 (𝑥𝑊 → (𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁))
13 fznn0sub2 13580 . . . . . . . . . . . 12 (𝑘 ∈ (0...𝑁) → (𝑁𝑘) ∈ (0...𝑁))
14 oveq1 7363 . . . . . . . . . . . . 13 ((♯‘𝑥) = 𝑁 → ((♯‘𝑥) − 𝑘) = (𝑁𝑘))
1514eleq1d 2824 . . . . . . . . . . . 12 ((♯‘𝑥) = 𝑁 → (((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ↔ (𝑁𝑘) ∈ (0...𝑁)))
1613, 15imbitrrid 247 . . . . . . . . . . 11 ((♯‘𝑥) = 𝑁 → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1716adantl 482 . . . . . . . . . 10 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1812, 17syl 17 . . . . . . . . 9 (𝑥𝑊 → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1918adantl 482 . . . . . . . 8 ((𝑋𝑊𝑥𝑊) → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2019com12 32 . . . . . . 7 (𝑘 ∈ (0...𝑁) → ((𝑋𝑊𝑥𝑊) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2120adantr 481 . . . . . 6 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → ((𝑋𝑊𝑥𝑊) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2221imp 407 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁))
2322adantr 481 . . . 4 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁))
24 simpr 485 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑋𝑊𝑥𝑊))
2524ancomd 462 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥𝑊𝑋𝑊))
2625adantr 481 . . . 4 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (𝑥𝑊𝑋𝑊))
2723, 26jca 516 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ∧ (𝑥𝑊𝑋𝑊)))
28 simpll 772 . . . . . . . . . . . . 13 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → 𝑥 ∈ Word (Vtx‘𝐺))
29 oveq2 7364 . . . . . . . . . . . . . . . . 17 (𝑁 = (♯‘𝑥) → (0...𝑁) = (0...(♯‘𝑥)))
3029eleq2d 2825 . . . . . . . . . . . . . . . 16 (𝑁 = (♯‘𝑥) → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3130eqcoms 2747 . . . . . . . . . . . . . . 15 ((♯‘𝑥) = 𝑁 → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3231adantl 482 . . . . . . . . . . . . . 14 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3332biimpa 477 . . . . . . . . . . . . 13 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → 𝑘 ∈ (0...(♯‘𝑥)))
3428, 33jca 516 . . . . . . . . . . . 12 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))))
3534ex 413 . . . . . . . . . . 11 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3612, 35syl 17 . . . . . . . . . 10 (𝑥𝑊 → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3736adantl 482 . . . . . . . . 9 ((𝑋𝑊𝑥𝑊) → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3837com12 32 . . . . . . . 8 (𝑘 ∈ (0...𝑁) → ((𝑋𝑊𝑥𝑊) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3938adantr 481 . . . . . . 7 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → ((𝑋𝑊𝑥𝑊) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
4039imp 407 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))))
414eqcomd 2745 . . . . . . 7 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → (𝑥 cyclShift 𝑘) = 𝑋)
4241adantr 481 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥 cyclShift 𝑘) = 𝑋)
43 oveq1 7363 . . . . . . . 8 (𝑋 = (𝑥 cyclShift 𝑘) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)))
4443eqcoms 2747 . . . . . . 7 ((𝑥 cyclShift 𝑘) = 𝑋 → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)))
45 elfzelz 13469 . . . . . . . 8 (𝑘 ∈ (0...(♯‘𝑥)) → 𝑘 ∈ ℤ)
46 2cshwid 14767 . . . . . . . 8 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ ℤ) → ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4745, 46sylan2 599 . . . . . . 7 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))) → ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4844, 47sylan9eqr 2796 . . . . . 6 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))) ∧ (𝑥 cyclShift 𝑘) = 𝑋) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4940, 42, 48syl2anc 590 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
5049eqcomd 2745 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → 𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)))
5150anim1i 621 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
527eleclclwwlknlem1 30148 . . 3 ((((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ∧ (𝑥𝑊𝑋𝑊)) → ((𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)))
5327, 51, 52sylc 65 . 2 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚))
549, 53impbida 806 1 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚) ↔ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 207  wa 396   = wceq 1547  wcel 2119  wrex 3063  cfv 6485  (class class class)co 7356  0cc0 11029  cmin 11368  cz 12515  ...cfz 13452  chash 14283  Word cword 14466   cyclShift ccsh 14741  Vtxcvtx 29083   ClWWalksN cclwwlkn 30112
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1802  ax-4 1816  ax-5 1917  ax-6 1974  ax-7 2015  ax-8 2121  ax-9 2129  ax-10 2152  ax-11 2168  ax-12 2189  ax-ext 2711  ax-rep 5199  ax-sep 5218  ax-nul 5228  ax-pow 5294  ax-pr 5362  ax-un 7678  ax-cnex 11085  ax-resscn 11086  ax-1cn 11087  ax-icn 11088  ax-addcl 11089  ax-addrcl 11090  ax-mulcl 11091  ax-mulrcl 11092  ax-mulcom 11093  ax-addass 11094  ax-mulass 11095  ax-distr 11096  ax-i2m1 11097  ax-1ne0 11098  ax-1rid 11099  ax-rnegex 11100  ax-rrecex 11101  ax-cnre 11102  ax-pre-lttri 11103  ax-pre-lttrn 11104  ax-pre-ltadd 11105  ax-pre-mulgt0 11106  ax-pre-sup 11107
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 854  df-3or 1093  df-3an 1094  df-tru 1550  df-fal 1560  df-ex 1787  df-nf 1791  df-sb 2074  df-mo 2543  df-eu 2573  df-clab 2718  df-cleq 2731  df-clel 2814  df-nfc 2888  df-ne 2935  df-nel 3039  df-ral 3054  df-rex 3064  df-rmo 3344  df-reu 3345  df-rab 3392  df-v 3433  df-sbc 3724  df-csb 3832  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-pss 3903  df-nul 4262  df-if 4455  df-pw 4531  df-sn 4556  df-pr 4558  df-op 4562  df-uni 4839  df-int 4878  df-iun 4923  df-br 5073  df-opab 5135  df-mpt 5154  df-tr 5180  df-id 5513  df-eprel 5518  df-po 5526  df-so 5527  df-fr 5571  df-we 5573  df-xp 5624  df-rel 5625  df-cnv 5626  df-co 5627  df-dm 5628  df-rn 5629  df-res 5630  df-ima 5631  df-pred 6252  df-ord 6313  df-on 6314  df-lim 6315  df-suc 6316  df-iota 6441  df-fun 6487  df-fn 6488  df-f 6489  df-f1 6490  df-fo 6491  df-f1o 6492  df-fv 6493  df-riota 7313  df-ov 7359  df-oprab 7360  df-mpo 7361  df-om 7807  df-1st 7931  df-2nd 7932  df-frecs 8221  df-wrecs 8252  df-recs 8301  df-rdg 8339  df-1o 8395  df-er 8633  df-map 8765  df-en 8884  df-dom 8885  df-sdom 8886  df-fin 8887  df-sup 9345  df-inf 9346  df-card 9854  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-div 11799  df-nn 12166  df-2 12235  df-n0 12429  df-z 12516  df-uz 12780  df-rp 12934  df-fz 13453  df-fzo 13600  df-fl 13742  df-mod 13820  df-hash 14284  df-word 14467  df-concat 14524  df-substr 14595  df-pfx 14625  df-csh 14742  df-clwwlk 30070  df-clwwlkn 30113
This theorem is referenced by:  eleclclwwlkn  30164
  Copyright terms: Public domain W3C validator