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

Theorem wrdred1hash 14356
Description: The length of a word truncated by a symbol. (Contributed by Alexander van der Vekens, 1-Nov-2017.) (Revised by AV, 29-Jan-2021.)
Assertion
Ref Expression
wrdred1hash ((𝐹 ∈ Word 𝑆 ∧ 1 ≤ (♯‘𝐹)) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1))

Proof of Theorem wrdred1hash
StepHypRef Expression
1 lencl 14328 . . 3 (𝐹 ∈ Word 𝑆 → (♯‘𝐹) ∈ ℕ0)
2 wrdf 14314 . . . 4 (𝐹 ∈ Word 𝑆𝐹:(0..^(♯‘𝐹))⟶𝑆)
3 ffn 6645 . . . 4 (𝐹:(0..^(♯‘𝐹))⟶𝑆𝐹 Fn (0..^(♯‘𝐹)))
4 nn0z 12436 . . . . . . . . . . 11 ((♯‘𝐹) ∈ ℕ0 → (♯‘𝐹) ∈ ℤ)
5 fzossrbm1 13509 . . . . . . . . . . 11 ((♯‘𝐹) ∈ ℤ → (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹)))
64, 5syl 17 . . . . . . . . . 10 ((♯‘𝐹) ∈ ℕ0 → (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹)))
76adantr 481 . . . . . . . . 9 (((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹)))
87adantl 482 . . . . . . . 8 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹)))
9 fnssresb 6600 . . . . . . . . 9 (𝐹 Fn (0..^(♯‘𝐹)) → ((𝐹 ↾ (0..^((♯‘𝐹) − 1))) Fn (0..^((♯‘𝐹) − 1)) ↔ (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹))))
109adantr 481 . . . . . . . 8 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → ((𝐹 ↾ (0..^((♯‘𝐹) − 1))) Fn (0..^((♯‘𝐹) − 1)) ↔ (0..^((♯‘𝐹) − 1)) ⊆ (0..^(♯‘𝐹))))
118, 10mpbird 256 . . . . . . 7 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → (𝐹 ↾ (0..^((♯‘𝐹) − 1))) Fn (0..^((♯‘𝐹) − 1)))
12 hashfn 14182 . . . . . . 7 ((𝐹 ↾ (0..^((♯‘𝐹) − 1))) Fn (0..^((♯‘𝐹) − 1)) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = (♯‘(0..^((♯‘𝐹) − 1))))
1311, 12syl 17 . . . . . 6 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = (♯‘(0..^((♯‘𝐹) − 1))))
14 1nn0 12342 . . . . . . . . 9 1 ∈ ℕ0
15 nn0sub2 12474 . . . . . . . . 9 ((1 ∈ ℕ0 ∧ (♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → ((♯‘𝐹) − 1) ∈ ℕ0)
1614, 15mp3an1 1447 . . . . . . . 8 (((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → ((♯‘𝐹) − 1) ∈ ℕ0)
17 hashfzo0 14237 . . . . . . . 8 (((♯‘𝐹) − 1) ∈ ℕ0 → (♯‘(0..^((♯‘𝐹) − 1))) = ((♯‘𝐹) − 1))
1816, 17syl 17 . . . . . . 7 (((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → (♯‘(0..^((♯‘𝐹) − 1))) = ((♯‘𝐹) − 1))
1918adantl 482 . . . . . 6 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → (♯‘(0..^((♯‘𝐹) − 1))) = ((♯‘𝐹) − 1))
2013, 19eqtrd 2776 . . . . 5 ((𝐹 Fn (0..^(♯‘𝐹)) ∧ ((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹))) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1))
2120ex 413 . . . 4 (𝐹 Fn (0..^(♯‘𝐹)) → (((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1)))
222, 3, 213syl 18 . . 3 (𝐹 ∈ Word 𝑆 → (((♯‘𝐹) ∈ ℕ0 ∧ 1 ≤ (♯‘𝐹)) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1)))
231, 22mpand 692 . 2 (𝐹 ∈ Word 𝑆 → (1 ≤ (♯‘𝐹) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1)))
2423imp 407 1 ((𝐹 ∈ Word 𝑆 ∧ 1 ≤ (♯‘𝐹)) → (♯‘(𝐹 ↾ (0..^((♯‘𝐹) − 1)))) = ((♯‘𝐹) − 1))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 396   = wceq 1540  wcel 2105  wss 3897   class class class wbr 5089  cres 5616   Fn wfn 6468  wf 6469  cfv 6473  (class class class)co 7329  0cc0 10964  1c1 10965  cle 11103  cmin 11298  0cn0 12326  cz 12412  ..^cfzo 13475  chash 14137  Word cword 14309
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 1912  ax-6 1970  ax-7 2010  ax-8 2107  ax-9 2115  ax-10 2136  ax-11 2153  ax-12 2170  ax-ext 2707  ax-rep 5226  ax-sep 5240  ax-nul 5247  ax-pow 5305  ax-pr 5369  ax-un 7642  ax-cnex 11020  ax-resscn 11021  ax-1cn 11022  ax-icn 11023  ax-addcl 11024  ax-addrcl 11025  ax-mulcl 11026  ax-mulrcl 11027  ax-mulcom 11028  ax-addass 11029  ax-mulass 11030  ax-distr 11031  ax-i2m1 11032  ax-1ne0 11033  ax-1rid 11034  ax-rnegex 11035  ax-rrecex 11036  ax-cnre 11037  ax-pre-lttri 11038  ax-pre-lttrn 11039  ax-pre-ltadd 11040  ax-pre-mulgt0 11041
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 845  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1781  df-nf 1785  df-sb 2067  df-mo 2538  df-eu 2567  df-clab 2714  df-cleq 2728  df-clel 2814  df-nfc 2886  df-ne 2941  df-nel 3047  df-ral 3062  df-rex 3071  df-reu 3350  df-rab 3404  df-v 3443  df-sbc 3727  df-csb 3843  df-dif 3900  df-un 3902  df-in 3904  df-ss 3914  df-pss 3916  df-nul 4269  df-if 4473  df-pw 4548  df-sn 4573  df-pr 4575  df-op 4579  df-uni 4852  df-int 4894  df-iun 4940  df-br 5090  df-opab 5152  df-mpt 5173  df-tr 5207  df-id 5512  df-eprel 5518  df-po 5526  df-so 5527  df-fr 5569  df-we 5571  df-xp 5620  df-rel 5621  df-cnv 5622  df-co 5623  df-dm 5624  df-rn 5625  df-res 5626  df-ima 5627  df-pred 6232  df-ord 6299  df-on 6300  df-lim 6301  df-suc 6302  df-iota 6425  df-fun 6475  df-fn 6476  df-f 6477  df-f1 6478  df-fo 6479  df-f1o 6480  df-fv 6481  df-riota 7286  df-ov 7332  df-oprab 7333  df-mpo 7334  df-om 7773  df-1st 7891  df-2nd 7892  df-frecs 8159  df-wrecs 8190  df-recs 8264  df-rdg 8303  df-1o 8359  df-er 8561  df-en 8797  df-dom 8798  df-sdom 8799  df-fin 8800  df-card 9788  df-pnf 11104  df-mnf 11105  df-xr 11106  df-ltxr 11107  df-le 11108  df-sub 11300  df-neg 11301  df-nn 12067  df-n0 12327  df-z 12413  df-uz 12676  df-fz 13333  df-fzo 13476  df-hash 14138  df-word 14310
This theorem is referenced by:  redwlklem  28240  redwlk  28241
  Copyright terms: Public domain W3C validator