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

Theorem swrdccat 14623
Description: The subword of a concatenation of two words as concatenation of subwords of the two concatenated words. (Contributed by Alexander van der Vekens, 29-May-2018.)
Hypothesis
Ref Expression
swrdccatin2.l 𝐿 = (♯‘𝐴)
Assertion
Ref Expression
swrdccat ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 ++ 𝐵) substr ⟨𝑀, 𝑁⟩) = ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩))))

Proof of Theorem swrdccat
StepHypRef Expression
1 swrdccatin2.l . . . . 5 𝐿 = (♯‘𝐴)
21pfxccat3 14622 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 ++ 𝐵) substr ⟨𝑀, 𝑁⟩) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿)))))))
32imp 407 . . 3 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵))))) → ((𝐴 ++ 𝐵) substr ⟨𝑀, 𝑁⟩) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))
4 lencl 14421 . . . . . 6 (𝐴 ∈ Word 𝑉 → (♯‘𝐴) ∈ ℕ0)
54adantr 481 . . . . 5 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (♯‘𝐴) ∈ ℕ0)
61eqcomi 2745 . . . . . . 7 (♯‘𝐴) = 𝐿
76eleq1i 2828 . . . . . 6 ((♯‘𝐴) ∈ ℕ0𝐿 ∈ ℕ0)
8 elfz2nn0 13532 . . . . . . . . 9 (𝑀 ∈ (0...𝑁) ↔ (𝑀 ∈ ℕ0𝑁 ∈ ℕ0𝑀𝑁))
9 iftrue 4492 . . . . . . . . . . . . . . . . . 18 (𝑁𝐿 → if(𝑁𝐿, 𝑁, 𝐿) = 𝑁)
109adantl 482 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → if(𝑁𝐿, 𝑁, 𝐿) = 𝑁)
1110opeq2d 4837 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩ = ⟨𝑀, 𝑁⟩)
1211oveq2d 7373 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) = (𝐴 substr ⟨𝑀, 𝑁⟩))
13 iftrue 4492 . . . . . . . . . . . . . . . . . . . 20 (0 ≤ (𝑀𝐿) → if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0) = (𝑀𝐿))
1413opeq1d 4836 . . . . . . . . . . . . . . . . . . 19 (0 ≤ (𝑀𝐿) → ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩ = ⟨(𝑀𝐿), (𝑁𝐿)⟩)
1514oveq2d 7373 . . . . . . . . . . . . . . . . . 18 (0 ≤ (𝑀𝐿) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
1615adantr 481 . . . . . . . . . . . . . . . . 17 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
17 simpr 485 . . . . . . . . . . . . . . . . . . . . 21 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → 𝐵 ∈ Word 𝑉)
18 nn0z 12524 . . . . . . . . . . . . . . . . . . . . . 22 (𝐿 ∈ ℕ0𝐿 ∈ ℤ)
19 nn0z 12524 . . . . . . . . . . . . . . . . . . . . . . . . 25 (𝑀 ∈ ℕ0𝑀 ∈ ℤ)
2019adantr 481 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → 𝑀 ∈ ℤ)
21 zsubcl 12545 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑀 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝑀𝐿) ∈ ℤ)
2220, 21sylan 580 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℤ) → (𝑀𝐿) ∈ ℤ)
23 nn0z 12524 . . . . . . . . . . . . . . . . . . . . . . . . 25 (𝑁 ∈ ℕ0𝑁 ∈ ℤ)
2423adantl 482 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → 𝑁 ∈ ℤ)
25 zsubcl 12545 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑁 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝑁𝐿) ∈ ℤ)
2624, 25sylan 580 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℤ) → (𝑁𝐿) ∈ ℤ)
2722, 26jca 512 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℤ) → ((𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ))
2818, 27sylan2 593 . . . . . . . . . . . . . . . . . . . . 21 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → ((𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ))
2917, 28anim12i 613 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝐵 ∈ Word 𝑉 ∧ ((𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ)))
30 3anass 1095 . . . . . . . . . . . . . . . . . . . 20 ((𝐵 ∈ Word 𝑉 ∧ (𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ) ↔ (𝐵 ∈ Word 𝑉 ∧ ((𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ)))
3129, 30sylibr 233 . . . . . . . . . . . . . . . . . . 19 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝐵 ∈ Word 𝑉 ∧ (𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ))
3231ad2antrl 726 . . . . . . . . . . . . . . . . . 18 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝐵 ∈ Word 𝑉 ∧ (𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ))
33 nn0re 12422 . . . . . . . . . . . . . . . . . . . . . . . 24 (𝑀 ∈ ℕ0𝑀 ∈ ℝ)
34 nn0re 12422 . . . . . . . . . . . . . . . . . . . . . . . 24 (𝑁 ∈ ℕ0𝑁 ∈ ℝ)
3533, 34anim12i 613 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → (𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ))
36 nn0re 12422 . . . . . . . . . . . . . . . . . . . . . . 23 (𝐿 ∈ ℕ0𝐿 ∈ ℝ)
37 subge0 11668 . . . . . . . . . . . . . . . . . . . . . . . . . 26 ((𝑀 ∈ ℝ ∧ 𝐿 ∈ ℝ) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
3837adantlr 713 . . . . . . . . . . . . . . . . . . . . . . . . 25 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
39 simpr 485 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 ((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) → 𝑁 ∈ ℝ)
4039adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → 𝑁 ∈ ℝ)
41 simpr 485 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → 𝐿 ∈ ℝ)
42 simpl 483 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 ((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) → 𝑀 ∈ ℝ)
4342adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → 𝑀 ∈ ℝ)
44 letr 11249 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 ((𝑁 ∈ ℝ ∧ 𝐿 ∈ ℝ ∧ 𝑀 ∈ ℝ) → ((𝑁𝐿𝐿𝑀) → 𝑁𝑀))
4540, 41, 43, 44syl3anc 1371 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → ((𝑁𝐿𝐿𝑀) → 𝑁𝑀))
4645expcomd 417 . . . . . . . . . . . . . . . . . . . . . . . . 25 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → (𝐿𝑀 → (𝑁𝐿𝑁𝑀)))
4738, 46sylbid 239 . . . . . . . . . . . . . . . . . . . . . . . 24 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → (0 ≤ (𝑀𝐿) → (𝑁𝐿𝑁𝑀)))
4847com23 86 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℝ ∧ 𝑁 ∈ ℝ) ∧ 𝐿 ∈ ℝ) → (𝑁𝐿 → (0 ≤ (𝑀𝐿) → 𝑁𝑀)))
4935, 36, 48syl2an 596 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝑁𝐿 → (0 ≤ (𝑀𝐿) → 𝑁𝑀)))
5049adantl 482 . . . . . . . . . . . . . . . . . . . . 21 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝑁𝐿 → (0 ≤ (𝑀𝐿) → 𝑁𝑀)))
5150imp 407 . . . . . . . . . . . . . . . . . . . 20 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (0 ≤ (𝑀𝐿) → 𝑁𝑀))
5251impcom 408 . . . . . . . . . . . . . . . . . . 19 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → 𝑁𝑀)
5334adantl 482 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → 𝑁 ∈ ℝ)
5453adantr 481 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → 𝑁 ∈ ℝ)
5533adantr 481 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → 𝑀 ∈ ℝ)
5655adantr 481 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → 𝑀 ∈ ℝ)
5736adantl 482 . . . . . . . . . . . . . . . . . . . . . . 23 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → 𝐿 ∈ ℝ)
5854, 56, 573jca 1128 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝑁 ∈ ℝ ∧ 𝑀 ∈ ℝ ∧ 𝐿 ∈ ℝ))
5958adantl 482 . . . . . . . . . . . . . . . . . . . . 21 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝑁 ∈ ℝ ∧ 𝑀 ∈ ℝ ∧ 𝐿 ∈ ℝ))
6059ad2antrl 726 . . . . . . . . . . . . . . . . . . . 20 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝑁 ∈ ℝ ∧ 𝑀 ∈ ℝ ∧ 𝐿 ∈ ℝ))
61 lesub1 11649 . . . . . . . . . . . . . . . . . . . 20 ((𝑁 ∈ ℝ ∧ 𝑀 ∈ ℝ ∧ 𝐿 ∈ ℝ) → (𝑁𝑀 ↔ (𝑁𝐿) ≤ (𝑀𝐿)))
6260, 61syl 17 . . . . . . . . . . . . . . . . . . 19 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝑁𝑀 ↔ (𝑁𝐿) ≤ (𝑀𝐿)))
6352, 62mpbid 231 . . . . . . . . . . . . . . . . . 18 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝑁𝐿) ≤ (𝑀𝐿))
64 swrdlend 14541 . . . . . . . . . . . . . . . . . 18 ((𝐵 ∈ Word 𝑉 ∧ (𝑀𝐿) ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ) → ((𝑁𝐿) ≤ (𝑀𝐿) → (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩) = ∅))
6532, 63, 64sylc 65 . . . . . . . . . . . . . . . . 17 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩) = ∅)
6616, 65eqtrd 2776 . . . . . . . . . . . . . . . 16 ((0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = ∅)
67 iffalse 4495 . . . . . . . . . . . . . . . . . . 19 (¬ 0 ≤ (𝑀𝐿) → if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0) = 0)
6867opeq1d 4836 . . . . . . . . . . . . . . . . . 18 (¬ 0 ≤ (𝑀𝐿) → ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩ = ⟨0, (𝑁𝐿)⟩)
6968oveq2d 7373 . . . . . . . . . . . . . . . . 17 (¬ 0 ≤ (𝑀𝐿) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 substr ⟨0, (𝑁𝐿)⟩))
7017adantr 481 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → 𝐵 ∈ Word 𝑉)
7170adantr 481 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → 𝐵 ∈ Word 𝑉)
72 0zd 12511 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → 0 ∈ ℤ)
7324, 18, 25syl2an 596 . . . . . . . . . . . . . . . . . . . . 21 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝑁𝐿) ∈ ℤ)
7473adantl 482 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝑁𝐿) ∈ ℤ)
7574adantr 481 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝑁𝐿) ∈ ℤ)
7671, 72, 753jca 1128 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝐵 ∈ Word 𝑉 ∧ 0 ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ))
7753, 36anim12i 613 . . . . . . . . . . . . . . . . . . . . 21 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝑁 ∈ ℝ ∧ 𝐿 ∈ ℝ))
7877adantl 482 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝑁 ∈ ℝ ∧ 𝐿 ∈ ℝ))
79 suble0 11669 . . . . . . . . . . . . . . . . . . . 20 ((𝑁 ∈ ℝ ∧ 𝐿 ∈ ℝ) → ((𝑁𝐿) ≤ 0 ↔ 𝑁𝐿))
8078, 79syl 17 . . . . . . . . . . . . . . . . . . 19 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → ((𝑁𝐿) ≤ 0 ↔ 𝑁𝐿))
8180biimpar 478 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝑁𝐿) ≤ 0)
82 swrdlend 14541 . . . . . . . . . . . . . . . . . 18 ((𝐵 ∈ Word 𝑉 ∧ 0 ∈ ℤ ∧ (𝑁𝐿) ∈ ℤ) → ((𝑁𝐿) ≤ 0 → (𝐵 substr ⟨0, (𝑁𝐿)⟩) = ∅))
8376, 81, 82sylc 65 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝐵 substr ⟨0, (𝑁𝐿)⟩) = ∅)
8469, 83sylan9eq 2796 . . . . . . . . . . . . . . . 16 ((¬ 0 ≤ (𝑀𝐿) ∧ (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿)) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = ∅)
8566, 84pm2.61ian 810 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = ∅)
8612, 85oveq12d 7375 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅))
87 swrdcl 14533 . . . . . . . . . . . . . . . . . 18 (𝐴 ∈ Word 𝑉 → (𝐴 substr ⟨𝑀, 𝑁⟩) ∈ Word 𝑉)
88 ccatrid 14475 . . . . . . . . . . . . . . . . . 18 ((𝐴 substr ⟨𝑀, 𝑁⟩) ∈ Word 𝑉 → ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅) = (𝐴 substr ⟨𝑀, 𝑁⟩))
8987, 88syl 17 . . . . . . . . . . . . . . . . 17 (𝐴 ∈ Word 𝑉 → ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅) = (𝐴 substr ⟨𝑀, 𝑁⟩))
9089adantr 481 . . . . . . . . . . . . . . . 16 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅) = (𝐴 substr ⟨𝑀, 𝑁⟩))
9190adantr 481 . . . . . . . . . . . . . . 15 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅) = (𝐴 substr ⟨𝑀, 𝑁⟩))
9291adantr 481 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → ((𝐴 substr ⟨𝑀, 𝑁⟩) ++ ∅) = (𝐴 substr ⟨𝑀, 𝑁⟩))
9386, 92eqtrd 2776 . . . . . . . . . . . . 13 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝑁𝐿) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = (𝐴 substr ⟨𝑀, 𝑁⟩))
94 iffalse 4495 . . . . . . . . . . . . . . . . . . 19 𝑁𝐿 → if(𝑁𝐿, 𝑁, 𝐿) = 𝐿)
95943ad2ant2 1134 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → if(𝑁𝐿, 𝑁, 𝐿) = 𝐿)
9695opeq2d 4837 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩ = ⟨𝑀, 𝐿⟩)
9796oveq2d 7373 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → (𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) = (𝐴 substr ⟨𝑀, 𝐿⟩))
98 simpl 483 . . . . . . . . . . . . . . . . . . . . 21 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → 𝐴 ∈ Word 𝑉)
9998, 20, 183anim123i 1151 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ (𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝐴 ∈ Word 𝑉𝑀 ∈ ℤ ∧ 𝐿 ∈ ℤ))
100993expb 1120 . . . . . . . . . . . . . . . . . . 19 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝐴 ∈ Word 𝑉𝑀 ∈ ℤ ∧ 𝐿 ∈ ℤ))
101 swrdlend 14541 . . . . . . . . . . . . . . . . . . 19 ((𝐴 ∈ Word 𝑉𝑀 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐿𝑀 → (𝐴 substr ⟨𝑀, 𝐿⟩) = ∅))
102100, 101syl 17 . . . . . . . . . . . . . . . . . 18 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝐿𝑀 → (𝐴 substr ⟨𝑀, 𝐿⟩) = ∅))
103102imp 407 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝐿𝑀) → (𝐴 substr ⟨𝑀, 𝐿⟩) = ∅)
1041033adant2 1131 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → (𝐴 substr ⟨𝑀, 𝐿⟩) = ∅)
10597, 104eqtrd 2776 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → (𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) = ∅)
10655, 36, 37syl2an 596 . . . . . . . . . . . . . . . . . . . . 21 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
107106biimprd 247 . . . . . . . . . . . . . . . . . . . 20 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (𝐿𝑀 → 0 ≤ (𝑀𝐿)))
108107adantl 482 . . . . . . . . . . . . . . . . . . 19 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (𝐿𝑀 → 0 ≤ (𝑀𝐿)))
109108imp 407 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ 𝐿𝑀) → 0 ≤ (𝑀𝐿))
1101093adant2 1131 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → 0 ≤ (𝑀𝐿))
111110, 14syl 17 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩ = ⟨(𝑀𝐿), (𝑁𝐿)⟩)
112111oveq2d 7373 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
113105, 112oveq12d 7375 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = (∅ ++ (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩)))
114 swrdcl 14533 . . . . . . . . . . . . . . . . . 18 (𝐵 ∈ Word 𝑉 → (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩) ∈ Word 𝑉)
115114adantl 482 . . . . . . . . . . . . . . . . 17 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩) ∈ Word 𝑉)
116 ccatlid 14474 . . . . . . . . . . . . . . . . 17 ((𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩) ∈ Word 𝑉 → (∅ ++ (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩)) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
117115, 116syl 17 . . . . . . . . . . . . . . . 16 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (∅ ++ (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩)) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
118117adantr 481 . . . . . . . . . . . . . . 15 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (∅ ++ (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩)) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
1191183ad2ant1 1133 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → (∅ ++ (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩)) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
120113, 119eqtrd 2776 . . . . . . . . . . . . 13 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿𝐿𝑀) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩))
121943ad2ant2 1134 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → if(𝑁𝐿, 𝑁, 𝐿) = 𝐿)
122121opeq2d 4837 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩ = ⟨𝑀, 𝐿⟩)
123122oveq2d 7373 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) = (𝐴 substr ⟨𝑀, 𝐿⟩))
12433, 36, 37syl2an 596 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝑀 ∈ ℕ0𝐿 ∈ ℕ0) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
125124adantlr 713 . . . . . . . . . . . . . . . . . . . . . 22 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
126125adantl 482 . . . . . . . . . . . . . . . . . . . . 21 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (0 ≤ (𝑀𝐿) ↔ 𝐿𝑀))
127126biimpd 228 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (0 ≤ (𝑀𝐿) → 𝐿𝑀))
128127con3dimp 409 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝐿𝑀) → ¬ 0 ≤ (𝑀𝐿))
1291283adant2 1131 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → ¬ 0 ≤ (𝑀𝐿))
130129, 67syl 17 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0) = 0)
131130opeq1d 4836 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩ = ⟨0, (𝑁𝐿)⟩)
132131oveq2d 7373 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 substr ⟨0, (𝑁𝐿)⟩))
133703ad2ant1 1133 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → 𝐵 ∈ Word 𝑉)
134 simplrr 776 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿) → 𝐿 ∈ ℕ0)
135 simprlr 778 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → 𝑁 ∈ ℕ0)
136135adantr 481 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿) → 𝑁 ∈ ℕ0)
137 ltnle 11234 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝐿 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝐿 < 𝑁 ↔ ¬ 𝑁𝐿))
138 ltle 11243 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝐿 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝐿 < 𝑁𝐿𝑁))
139137, 138sylbird 259 . . . . . . . . . . . . . . . . . . . . . 22 ((𝐿 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (¬ 𝑁𝐿𝐿𝑁))
14036, 53, 139syl2anr 597 . . . . . . . . . . . . . . . . . . . . 21 (((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0) → (¬ 𝑁𝐿𝐿𝑁))
141140adantl 482 . . . . . . . . . . . . . . . . . . . 20 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → (¬ 𝑁𝐿𝐿𝑁))
142141imp 407 . . . . . . . . . . . . . . . . . . 19 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿) → 𝐿𝑁)
143 nn0sub2 12564 . . . . . . . . . . . . . . . . . . 19 ((𝐿 ∈ ℕ0𝑁 ∈ ℕ0𝐿𝑁) → (𝑁𝐿) ∈ ℕ0)
144134, 136, 142, 143syl3anc 1371 . . . . . . . . . . . . . . . . . 18 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿) → (𝑁𝐿) ∈ ℕ0)
1451443adant3 1132 . . . . . . . . . . . . . . . . 17 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝑁𝐿) ∈ ℕ0)
146133, 145jca 512 . . . . . . . . . . . . . . . 16 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝐵 ∈ Word 𝑉 ∧ (𝑁𝐿) ∈ ℕ0))
147 pfxval 14561 . . . . . . . . . . . . . . . 16 ((𝐵 ∈ Word 𝑉 ∧ (𝑁𝐿) ∈ ℕ0) → (𝐵 prefix (𝑁𝐿)) = (𝐵 substr ⟨0, (𝑁𝐿)⟩))
148146, 147syl 17 . . . . . . . . . . . . . . 15 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝐵 prefix (𝑁𝐿)) = (𝐵 substr ⟨0, (𝑁𝐿)⟩))
149132, 148eqtr4d 2779 . . . . . . . . . . . . . 14 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩) = (𝐵 prefix (𝑁𝐿)))
150123, 149oveq12d 7375 . . . . . . . . . . . . 13 ((((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) ∧ ¬ 𝑁𝐿 ∧ ¬ 𝐿𝑀) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))
15193, 120, 1502if2 4541 . . . . . . . . . . . 12 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) ∧ 𝐿 ∈ ℕ0)) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))
152151exp32 421 . . . . . . . . . . 11 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → (𝐿 ∈ ℕ0 → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
153152com12 32 . . . . . . . . . 10 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0) → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐿 ∈ ℕ0 → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
1541533adant3 1132 . . . . . . . . 9 ((𝑀 ∈ ℕ0𝑁 ∈ ℕ0𝑀𝑁) → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐿 ∈ ℕ0 → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
1558, 154sylbi 216 . . . . . . . 8 (𝑀 ∈ (0...𝑁) → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐿 ∈ ℕ0 → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
156155adantr 481 . . . . . . 7 ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐿 ∈ ℕ0 → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
157156com13 88 . . . . . 6 (𝐿 ∈ ℕ0 → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
1587, 157sylbi 216 . . . . 5 ((♯‘𝐴) ∈ ℕ0 → ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))))
1595, 158mpcom 38 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿)))))))
160159imp 407 . . 3 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵))))) → ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)) = if(𝑁𝐿, (𝐴 substr ⟨𝑀, 𝑁⟩), if(𝐿𝑀, (𝐵 substr ⟨(𝑀𝐿), (𝑁𝐿)⟩), ((𝐴 substr ⟨𝑀, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))))
1613, 160eqtr4d 2779 . 2 (((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵))))) → ((𝐴 ++ 𝐵) substr ⟨𝑀, 𝑁⟩) = ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩)))
162161ex 413 1 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(𝐿 + (♯‘𝐵)))) → ((𝐴 ++ 𝐵) substr ⟨𝑀, 𝑁⟩) = ((𝐴 substr ⟨𝑀, if(𝑁𝐿, 𝑁, 𝐿)⟩) ++ (𝐵 substr ⟨if(0 ≤ (𝑀𝐿), (𝑀𝐿), 0), (𝑁𝐿)⟩))))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 205  wa 396  w3a 1087   = wceq 1541  wcel 2106  c0 4282  ifcif 4486  cop 4592   class class class wbr 5105  cfv 6496  (class class class)co 7357  cr 11050  0cc0 11051   + caddc 11054   < clt 11189  cle 11190  cmin 11385  0cn0 12413  cz 12499  ...cfz 13424  chash 14230  Word cword 14402   ++ cconcat 14458   substr csubstr 14528   prefix cpfx 14558
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2707  ax-rep 5242  ax-sep 5256  ax-nul 5263  ax-pow 5320  ax-pr 5384  ax-un 7672  ax-cnex 11107  ax-resscn 11108  ax-1cn 11109  ax-icn 11110  ax-addcl 11111  ax-addrcl 11112  ax-mulcl 11113  ax-mulrcl 11114  ax-mulcom 11115  ax-addass 11116  ax-mulass 11117  ax-distr 11118  ax-i2m1 11119  ax-1ne0 11120  ax-1rid 11121  ax-rnegex 11122  ax-rrecex 11123  ax-cnre 11124  ax-pre-lttri 11125  ax-pre-lttrn 11126  ax-pre-ltadd 11127  ax-pre-mulgt0 11128
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3or 1088  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2538  df-eu 2567  df-clab 2714  df-cleq 2728  df-clel 2814  df-nfc 2889  df-ne 2944  df-nel 3050  df-ral 3065  df-rex 3074  df-reu 3354  df-rab 3408  df-v 3447  df-sbc 3740  df-csb 3856  df-dif 3913  df-un 3915  df-in 3917  df-ss 3927  df-pss 3929  df-nul 4283  df-if 4487  df-pw 4562  df-sn 4587  df-pr 4589  df-op 4593  df-uni 4866  df-int 4908  df-iun 4956  df-br 5106  df-opab 5168  df-mpt 5189  df-tr 5223  df-id 5531  df-eprel 5537  df-po 5545  df-so 5546  df-fr 5588  df-we 5590  df-xp 5639  df-rel 5640  df-cnv 5641  df-co 5642  df-dm 5643  df-rn 5644  df-res 5645  df-ima 5646  df-pred 6253  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6498  df-fn 6499  df-f 6500  df-f1 6501  df-fo 6502  df-f1o 6503  df-fv 6504  df-riota 7313  df-ov 7360  df-oprab 7361  df-mpo 7362  df-om 7803  df-1st 7921  df-2nd 7922  df-frecs 8212  df-wrecs 8243  df-recs 8317  df-rdg 8356  df-1o 8412  df-er 8648  df-en 8884  df-dom 8885  df-sdom 8886  df-fin 8887  df-card 9875  df-pnf 11191  df-mnf 11192  df-xr 11193  df-ltxr 11194  df-le 11195  df-sub 11387  df-neg 11388  df-nn 12154  df-n0 12414  df-z 12500  df-uz 12764  df-fz 13425  df-fzo 13568  df-hash 14231  df-word 14403  df-concat 14459  df-substr 14529  df-pfx 14559
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator