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

Theorem smumullem 16430
Description: Lemma for smumul 16431. (Contributed by Mario Carneiro, 22-Sep-2016.)
Hypotheses
Ref Expression
smumullem.a (πœ‘ β†’ 𝐴 ∈ β„€)
smumullem.b (πœ‘ β†’ 𝐡 ∈ β„€)
smumullem.n (πœ‘ β†’ 𝑁 ∈ β„•0)
Assertion
Ref Expression
smumullem (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡)))

Proof of Theorem smumullem
Dummy variables π‘˜ 𝑛 π‘₯ are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 smumullem.n . 2 (πœ‘ β†’ 𝑁 ∈ β„•0)
2 oveq2 7414 . . . . . . . . . 10 (π‘₯ = 0 β†’ (0..^π‘₯) = (0..^0))
3 fzo0 13653 . . . . . . . . . 10 (0..^0) = βˆ…
42, 3eqtrdi 2789 . . . . . . . . 9 (π‘₯ = 0 β†’ (0..^π‘₯) = βˆ…)
54ineq2d 4212 . . . . . . . 8 (π‘₯ = 0 β†’ ((bitsβ€˜π΄) ∩ (0..^π‘₯)) = ((bitsβ€˜π΄) ∩ βˆ…))
6 in0 4391 . . . . . . . 8 ((bitsβ€˜π΄) ∩ βˆ…) = βˆ…
75, 6eqtrdi 2789 . . . . . . 7 (π‘₯ = 0 β†’ ((bitsβ€˜π΄) ∩ (0..^π‘₯)) = βˆ…)
87oveq1d 7421 . . . . . 6 (π‘₯ = 0 β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (βˆ… smul (bitsβ€˜π΅)))
9 bitsss 16364 . . . . . . 7 (bitsβ€˜π΅) βŠ† β„•0
10 smu02 16425 . . . . . . 7 ((bitsβ€˜π΅) βŠ† β„•0 β†’ (βˆ… smul (bitsβ€˜π΅)) = βˆ…)
119, 10ax-mp 5 . . . . . 6 (βˆ… smul (bitsβ€˜π΅)) = βˆ…
128, 11eqtrdi 2789 . . . . 5 (π‘₯ = 0 β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = βˆ…)
13 oveq2 7414 . . . . . . . 8 (π‘₯ = 0 β†’ (2↑π‘₯) = (2↑0))
14 2cn 12284 . . . . . . . . 9 2 ∈ β„‚
15 exp0 14028 . . . . . . . . 9 (2 ∈ β„‚ β†’ (2↑0) = 1)
1614, 15ax-mp 5 . . . . . . . 8 (2↑0) = 1
1713, 16eqtrdi 2789 . . . . . . 7 (π‘₯ = 0 β†’ (2↑π‘₯) = 1)
1817oveq2d 7422 . . . . . 6 (π‘₯ = 0 β†’ (𝐴 mod (2↑π‘₯)) = (𝐴 mod 1))
1918fvoveq1d 7428 . . . . 5 (π‘₯ = 0 β†’ (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) = (bitsβ€˜((𝐴 mod 1) Β· 𝐡)))
2012, 19eqeq12d 2749 . . . 4 (π‘₯ = 0 β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) ↔ βˆ… = (bitsβ€˜((𝐴 mod 1) Β· 𝐡))))
2120imbi2d 341 . . 3 (π‘₯ = 0 β†’ ((πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡))) ↔ (πœ‘ β†’ βˆ… = (bitsβ€˜((𝐴 mod 1) Β· 𝐡)))))
22 oveq2 7414 . . . . . . 7 (π‘₯ = π‘˜ β†’ (0..^π‘₯) = (0..^π‘˜))
2322ineq2d 4212 . . . . . 6 (π‘₯ = π‘˜ β†’ ((bitsβ€˜π΄) ∩ (0..^π‘₯)) = ((bitsβ€˜π΄) ∩ (0..^π‘˜)))
2423oveq1d 7421 . . . . 5 (π‘₯ = π‘˜ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)))
25 oveq2 7414 . . . . . . 7 (π‘₯ = π‘˜ β†’ (2↑π‘₯) = (2β†‘π‘˜))
2625oveq2d 7422 . . . . . 6 (π‘₯ = π‘˜ β†’ (𝐴 mod (2↑π‘₯)) = (𝐴 mod (2β†‘π‘˜)))
2726fvoveq1d 7428 . . . . 5 (π‘₯ = π‘˜ β†’ (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)))
2824, 27eqeq12d 2749 . . . 4 (π‘₯ = π‘˜ β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) ↔ (((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡))))
2928imbi2d 341 . . 3 (π‘₯ = π‘˜ β†’ ((πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡))) ↔ (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)))))
30 oveq2 7414 . . . . . . 7 (π‘₯ = (π‘˜ + 1) β†’ (0..^π‘₯) = (0..^(π‘˜ + 1)))
3130ineq2d 4212 . . . . . 6 (π‘₯ = (π‘˜ + 1) β†’ ((bitsβ€˜π΄) ∩ (0..^π‘₯)) = ((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))))
3231oveq1d 7421 . . . . 5 (π‘₯ = (π‘˜ + 1) β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)))
33 oveq2 7414 . . . . . . 7 (π‘₯ = (π‘˜ + 1) β†’ (2↑π‘₯) = (2↑(π‘˜ + 1)))
3433oveq2d 7422 . . . . . 6 (π‘₯ = (π‘˜ + 1) β†’ (𝐴 mod (2↑π‘₯)) = (𝐴 mod (2↑(π‘˜ + 1))))
3534fvoveq1d 7428 . . . . 5 (π‘₯ = (π‘˜ + 1) β†’ (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)))
3632, 35eqeq12d 2749 . . . 4 (π‘₯ = (π‘˜ + 1) β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) ↔ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡))))
3736imbi2d 341 . . 3 (π‘₯ = (π‘˜ + 1) β†’ ((πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡))) ↔ (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)))))
38 oveq2 7414 . . . . . . 7 (π‘₯ = 𝑁 β†’ (0..^π‘₯) = (0..^𝑁))
3938ineq2d 4212 . . . . . 6 (π‘₯ = 𝑁 β†’ ((bitsβ€˜π΄) ∩ (0..^π‘₯)) = ((bitsβ€˜π΄) ∩ (0..^𝑁)))
4039oveq1d 7421 . . . . 5 (π‘₯ = 𝑁 β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)))
41 oveq2 7414 . . . . . . 7 (π‘₯ = 𝑁 β†’ (2↑π‘₯) = (2↑𝑁))
4241oveq2d 7422 . . . . . 6 (π‘₯ = 𝑁 β†’ (𝐴 mod (2↑π‘₯)) = (𝐴 mod (2↑𝑁)))
4342fvoveq1d 7428 . . . . 5 (π‘₯ = 𝑁 β†’ (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡)))
4440, 43eqeq12d 2749 . . . 4 (π‘₯ = 𝑁 β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡)) ↔ (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡))))
4544imbi2d 341 . . 3 (π‘₯ = 𝑁 β†’ ((πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘₯)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑π‘₯)) Β· 𝐡))) ↔ (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡)))))
46 smumullem.a . . . . . . . 8 (πœ‘ β†’ 𝐴 ∈ β„€)
47 zmod10 13849 . . . . . . . 8 (𝐴 ∈ β„€ β†’ (𝐴 mod 1) = 0)
4846, 47syl 17 . . . . . . 7 (πœ‘ β†’ (𝐴 mod 1) = 0)
4948oveq1d 7421 . . . . . 6 (πœ‘ β†’ ((𝐴 mod 1) Β· 𝐡) = (0 Β· 𝐡))
50 smumullem.b . . . . . . . 8 (πœ‘ β†’ 𝐡 ∈ β„€)
5150zcnd 12664 . . . . . . 7 (πœ‘ β†’ 𝐡 ∈ β„‚)
5251mul02d 11409 . . . . . 6 (πœ‘ β†’ (0 Β· 𝐡) = 0)
5349, 52eqtrd 2773 . . . . 5 (πœ‘ β†’ ((𝐴 mod 1) Β· 𝐡) = 0)
5453fveq2d 6893 . . . 4 (πœ‘ β†’ (bitsβ€˜((𝐴 mod 1) Β· 𝐡)) = (bitsβ€˜0))
55 0bits 16377 . . . 4 (bitsβ€˜0) = βˆ…
5654, 55eqtr2di 2790 . . 3 (πœ‘ β†’ βˆ… = (bitsβ€˜((𝐴 mod 1) Β· 𝐡)))
57 oveq1 7413 . . . . . 6 ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}) = ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
58 bitsss 16364 . . . . . . . . 9 (bitsβ€˜π΄) βŠ† β„•0
5958a1i 11 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (bitsβ€˜π΄) βŠ† β„•0)
609a1i 11 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (bitsβ€˜π΅) βŠ† β„•0)
61 simpr 486 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ π‘˜ ∈ β„•0)
6259, 60, 61smup1 16427 . . . . . . 7 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
63 bitsinv1lem 16379 . . . . . . . . . . . 12 ((𝐴 ∈ β„€ ∧ π‘˜ ∈ β„•0) β†’ (𝐴 mod (2↑(π‘˜ + 1))) = ((𝐴 mod (2β†‘π‘˜)) + if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))
6446, 63sylan 581 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (𝐴 mod (2↑(π‘˜ + 1))) = ((𝐴 mod (2β†‘π‘˜)) + if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))
6564oveq1d 7421 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡) = (((𝐴 mod (2β†‘π‘˜)) + if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)) Β· 𝐡))
6646adantr 482 . . . . . . . . . . . . 13 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ 𝐴 ∈ β„€)
67 2nn 12282 . . . . . . . . . . . . . . 15 2 ∈ β„•
6867a1i 11 . . . . . . . . . . . . . 14 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ 2 ∈ β„•)
6968, 61nnexpcld 14205 . . . . . . . . . . . . 13 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (2β†‘π‘˜) ∈ β„•)
7066, 69zmodcld 13854 . . . . . . . . . . . 12 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (𝐴 mod (2β†‘π‘˜)) ∈ β„•0)
7170nn0cnd 12531 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (𝐴 mod (2β†‘π‘˜)) ∈ β„‚)
7269nnnn0d 12529 . . . . . . . . . . . . 13 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (2β†‘π‘˜) ∈ β„•0)
73 0nn0 12484 . . . . . . . . . . . . 13 0 ∈ β„•0
74 ifcl 4573 . . . . . . . . . . . . 13 (((2β†‘π‘˜) ∈ β„•0 ∧ 0 ∈ β„•0) β†’ if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) ∈ β„•0)
7572, 73, 74sylancl 587 . . . . . . . . . . . 12 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) ∈ β„•0)
7675nn0cnd 12531 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) ∈ β„‚)
7751adantr 482 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ 𝐡 ∈ β„‚)
7871, 76, 77adddird 11236 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (((𝐴 mod (2β†‘π‘˜)) + if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)) Β· 𝐡) = (((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) Β· 𝐡)))
7976, 77mulcomd 11232 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) Β· 𝐡) = (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))
8079oveq2d 7422 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) Β· 𝐡)) = (((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0))))
8165, 78, 803eqtrd 2777 . . . . . . . . 9 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡) = (((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0))))
8281fveq2d 6893 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)) = (bitsβ€˜(((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))))
8370nn0zd 12581 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (𝐴 mod (2β†‘π‘˜)) ∈ β„€)
8450adantr 482 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ 𝐡 ∈ β„€)
8583, 84zmulcld 12669 . . . . . . . . 9 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) ∈ β„€)
8675nn0zd 12581 . . . . . . . . . 10 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) ∈ β„€)
8784, 86zmulcld 12669 . . . . . . . . 9 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)) ∈ β„€)
88 sadadd 16405 . . . . . . . . 9 ((((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) ∈ β„€ ∧ (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)) ∈ β„€) β†’ ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))) = (bitsβ€˜(((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))))
8985, 87, 88syl2anc 585 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))) = (bitsβ€˜(((𝐴 mod (2β†‘π‘˜)) Β· 𝐡) + (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))))
90 oveq2 7414 . . . . . . . . . . 11 ((2β†‘π‘˜) = if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) β†’ (𝐡 Β· (2β†‘π‘˜)) = (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))
9190fveqeq2d 6897 . . . . . . . . . 10 ((2β†‘π‘˜) = if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) β†’ ((bitsβ€˜(𝐡 Β· (2β†‘π‘˜))) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))} ↔ (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0))) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
92 oveq2 7414 . . . . . . . . . . 11 (0 = if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) β†’ (𝐡 Β· 0) = (𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))
9392fveqeq2d 6897 . . . . . . . . . 10 (0 = if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0) β†’ ((bitsβ€˜(𝐡 Β· 0)) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))} ↔ (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0))) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
94 bitsshft 16413 . . . . . . . . . . . 12 ((𝐡 ∈ β„€ ∧ π‘˜ ∈ β„•0) β†’ {𝑛 ∈ β„•0 ∣ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)} = (bitsβ€˜(𝐡 Β· (2β†‘π‘˜))))
9550, 94sylan 581 . . . . . . . . . . 11 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ {𝑛 ∈ β„•0 ∣ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)} = (bitsβ€˜(𝐡 Β· (2β†‘π‘˜))))
96 ibar 530 . . . . . . . . . . . 12 (π‘˜ ∈ (bitsβ€˜π΄) β†’ ((𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅) ↔ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))))
9796rabbidv 3441 . . . . . . . . . . 11 (π‘˜ ∈ (bitsβ€˜π΄) β†’ {𝑛 ∈ β„•0 ∣ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)} = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))})
9895, 97sylan9req 2794 . . . . . . . . . 10 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ π‘˜ ∈ (bitsβ€˜π΄)) β†’ (bitsβ€˜(𝐡 Β· (2β†‘π‘˜))) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))})
9977adantr 482 . . . . . . . . . . . . 13 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ 𝐡 ∈ β„‚)
10099mul01d 11410 . . . . . . . . . . . 12 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ (𝐡 Β· 0) = 0)
101100fveq2d 6893 . . . . . . . . . . 11 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ (bitsβ€˜(𝐡 Β· 0)) = (bitsβ€˜0))
102 simpr 486 . . . . . . . . . . . . . 14 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ Β¬ π‘˜ ∈ (bitsβ€˜π΄))
103102intnanrd 491 . . . . . . . . . . . . 13 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ Β¬ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)))
104103ralrimivw 3151 . . . . . . . . . . . 12 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ βˆ€π‘› ∈ β„•0 Β¬ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)))
105 rabeq0 4384 . . . . . . . . . . . 12 ({𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))} = βˆ… ↔ βˆ€π‘› ∈ β„•0 Β¬ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅)))
106104, 105sylibr 233 . . . . . . . . . . 11 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))} = βˆ…)
10755, 101, 1063eqtr4a 2799 . . . . . . . . . 10 (((πœ‘ ∧ π‘˜ ∈ β„•0) ∧ Β¬ π‘˜ ∈ (bitsβ€˜π΄)) β†’ (bitsβ€˜(𝐡 Β· 0)) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))})
10891, 93, 98, 107ifbothda 4566 . . . . . . . . 9 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0))) = {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))})
109108oveq2d 7422 . . . . . . . 8 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd (bitsβ€˜(𝐡 Β· if(π‘˜ ∈ (bitsβ€˜π΄), (2β†‘π‘˜), 0)))) = ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
11082, 89, 1093eqtr2d 2779 . . . . . . 7 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)) = ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}))
11162, 110eqeq12d 2749 . . . . . 6 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)) ↔ ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))}) = ((bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) sadd {𝑛 ∈ β„•0 ∣ (π‘˜ ∈ (bitsβ€˜π΄) ∧ (𝑛 βˆ’ π‘˜) ∈ (bitsβ€˜π΅))})))
11257, 111imbitrrid 245 . . . . 5 ((πœ‘ ∧ π‘˜ ∈ β„•0) β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) β†’ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡))))
113112expcom 415 . . . 4 (π‘˜ ∈ β„•0 β†’ (πœ‘ β†’ ((((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡)) β†’ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)))))
114113a2d 29 . . 3 (π‘˜ ∈ β„•0 β†’ ((πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^π‘˜)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2β†‘π‘˜)) Β· 𝐡))) β†’ (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^(π‘˜ + 1))) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑(π‘˜ + 1))) Β· 𝐡)))))
11521, 29, 37, 45, 56, 114nn0ind 12654 . 2 (𝑁 ∈ β„•0 β†’ (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡))))
1161, 115mpcom 38 1 (πœ‘ β†’ (((bitsβ€˜π΄) ∩ (0..^𝑁)) smul (bitsβ€˜π΅)) = (bitsβ€˜((𝐴 mod (2↑𝑁)) Β· 𝐡)))
Colors of variables: wff setvar class
Syntax hints:  Β¬ wn 3   β†’ wi 4   ∧ wa 397   = wceq 1542   ∈ wcel 2107  βˆ€wral 3062  {crab 3433   ∩ cin 3947   βŠ† wss 3948  βˆ…c0 4322  ifcif 4528  β€˜cfv 6541  (class class class)co 7406  β„‚cc 11105  0cc0 11107  1c1 11108   + caddc 11110   Β· cmul 11112   βˆ’ cmin 11441  β„•cn 12209  2c2 12264  β„•0cn0 12469  β„€cz 12555  ..^cfzo 13624   mod cmo 13831  β†‘cexp 14024  bitscbits 16357   sadd csad 16358   smul csmu 16359
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1798  ax-4 1812  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2109  ax-9 2117  ax-10 2138  ax-11 2155  ax-12 2172  ax-ext 2704  ax-rep 5285  ax-sep 5299  ax-nul 5306  ax-pow 5363  ax-pr 5427  ax-un 7722  ax-inf2 9633  ax-cnex 11163  ax-resscn 11164  ax-1cn 11165  ax-icn 11166  ax-addcl 11167  ax-addrcl 11168  ax-mulcl 11169  ax-mulrcl 11170  ax-mulcom 11171  ax-addass 11172  ax-mulass 11173  ax-distr 11174  ax-i2m1 11175  ax-1ne0 11176  ax-1rid 11177  ax-rnegex 11178  ax-rrecex 11179  ax-cnre 11180  ax-pre-lttri 11181  ax-pre-lttrn 11182  ax-pre-ltadd 11183  ax-pre-mulgt0 11184  ax-pre-sup 11185
This theorem depends on definitions:  df-bi 206  df-an 398  df-or 847  df-3or 1089  df-3an 1090  df-xor 1511  df-tru 1545  df-fal 1555  df-had 1596  df-cad 1609  df-ex 1783  df-nf 1787  df-sb 2069  df-mo 2535  df-eu 2564  df-clab 2711  df-cleq 2725  df-clel 2811  df-nfc 2886  df-ne 2942  df-nel 3048  df-ral 3063  df-rex 3072  df-rmo 3377  df-reu 3378  df-rab 3434  df-v 3477  df-sbc 3778  df-csb 3894  df-dif 3951  df-un 3953  df-in 3955  df-ss 3965  df-pss 3967  df-nul 4323  df-if 4529  df-pw 4604  df-sn 4629  df-pr 4631  df-op 4635  df-uni 4909  df-int 4951  df-iun 4999  df-disj 5114  df-br 5149  df-opab 5211  df-mpt 5232  df-tr 5266  df-id 5574  df-eprel 5580  df-po 5588  df-so 5589  df-fr 5631  df-se 5632  df-we 5633  df-xp 5682  df-rel 5683  df-cnv 5684  df-co 5685  df-dm 5686  df-rn 5687  df-res 5688  df-ima 5689  df-pred 6298  df-ord 6365  df-on 6366  df-lim 6367  df-suc 6368  df-iota 6493  df-fun 6543  df-fn 6544  df-f 6545  df-f1 6546  df-fo 6547  df-f1o 6548  df-fv 6549  df-isom 6550  df-riota 7362  df-ov 7409  df-oprab 7410  df-mpo 7411  df-om 7853  df-1st 7972  df-2nd 7973  df-frecs 8263  df-wrecs 8294  df-recs 8368  df-rdg 8407  df-1o 8463  df-2o 8464  df-oadd 8467  df-er 8700  df-map 8819  df-pm 8820  df-en 8937  df-dom 8938  df-sdom 8939  df-fin 8940  df-sup 9434  df-inf 9435  df-oi 9502  df-dju 9893  df-card 9931  df-pnf 11247  df-mnf 11248  df-xr 11249  df-ltxr 11250  df-le 11251  df-sub 11443  df-neg 11444  df-div 11869  df-nn 12210  df-2 12272  df-3 12273  df-n0 12470  df-xnn0 12542  df-z 12556  df-uz 12820  df-rp 12972  df-fz 13482  df-fzo 13625  df-fl 13754  df-mod 13832  df-seq 13964  df-exp 14025  df-hash 14288  df-cj 15043  df-re 15044  df-im 15045  df-sqrt 15179  df-abs 15180  df-clim 15429  df-sum 15630  df-dvds 16195  df-bits 16360  df-sad 16389  df-smu 16414
This theorem is referenced by:  smumul  16431
  Copyright terms: Public domain W3C validator