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

Theorem karatsuba 17025
Description: The Karatsuba multiplication algorithm. If 𝑋 and 𝑌 are decomposed into two groups of digits of length 𝑀 (only the lower group is known to be this size but the algorithm is most efficient when the partition is chosen near the middle of the digit string), then 𝑋𝑌 can be written in three groups of digits, where each group needs only one multiplication. Thus, we can halve both inputs with only three multiplications on the smaller operands, yielding an asymptotic improvement of n^(log2 3) instead of n^2 for the "naive" algorithm decmul1c 12686. (Contributed by Mario Carneiro, 16-Jul-2015.) (Revised by AV, 9-Sep-2021.)
Hypotheses
Ref Expression
karatsuba.a 𝐴 ∈ ℕ0
karatsuba.b 𝐵 ∈ ℕ0
karatsuba.c 𝐶 ∈ ℕ0
karatsuba.d 𝐷 ∈ ℕ0
karatsuba.s 𝑆 ∈ ℕ0
karatsuba.m 𝑀 ∈ ℕ0
karatsuba.r (𝐴 · 𝐶) = 𝑅
karatsuba.t (𝐵 · 𝐷) = 𝑇
karatsuba.e ((𝐴 + 𝐵) · (𝐶 + 𝐷)) = ((𝑅 + 𝑆) + 𝑇)
karatsuba.x ((𝐴 · (10↑𝑀)) + 𝐵) = 𝑋
karatsuba.y ((𝐶 · (10↑𝑀)) + 𝐷) = 𝑌
karatsuba.w ((𝑅 · (10↑𝑀)) + 𝑆) = 𝑊
karatsuba.z ((𝑊 · (10↑𝑀)) + 𝑇) = 𝑍
Assertion
Ref Expression
karatsuba (𝑋 · 𝑌) = 𝑍

Proof of Theorem karatsuba
StepHypRef Expression
1 karatsuba.a . . . . . 6 𝐴 ∈ ℕ0
21nn0cni 12427 . . . . 5 𝐴 ∈ ℂ
3 10nn0 12639 . . . . . . 7 10 ∈ ℕ0
43nn0cni 12427 . . . . . 6 10 ∈ ℂ
5 karatsuba.m . . . . . 6 𝑀 ∈ ℕ0
6 expcl 14016 . . . . . 6 ((10 ∈ ℂ ∧ 𝑀 ∈ ℕ0) → (10↑𝑀) ∈ ℂ)
74, 5, 6mp2an 693 . . . . 5 (10↑𝑀) ∈ ℂ
82, 7mulcli 11153 . . . 4 (𝐴 · (10↑𝑀)) ∈ ℂ
9 karatsuba.b . . . . 5 𝐵 ∈ ℕ0
109nn0cni 12427 . . . 4 𝐵 ∈ ℂ
11 karatsuba.c . . . . . 6 𝐶 ∈ ℕ0
1211nn0cni 12427 . . . . 5 𝐶 ∈ ℂ
1312, 7mulcli 11153 . . . 4 (𝐶 · (10↑𝑀)) ∈ ℂ
14 karatsuba.d . . . . 5 𝐷 ∈ ℕ0
1514nn0cni 12427 . . . 4 𝐷 ∈ ℂ
168, 10, 13, 15muladdi 11602 . . 3 (((𝐴 · (10↑𝑀)) + 𝐵) · ((𝐶 · (10↑𝑀)) + 𝐷)) = ((((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (𝐷 · 𝐵)) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵)))
178, 13mulcli 11153 . . . 4 ((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) ∈ ℂ
1815, 10mulcli 11153 . . . 4 (𝐷 · 𝐵) ∈ ℂ
198, 15mulcli 11153 . . . . 5 ((𝐴 · (10↑𝑀)) · 𝐷) ∈ ℂ
2013, 10mulcli 11153 . . . . 5 ((𝐶 · (10↑𝑀)) · 𝐵) ∈ ℂ
2119, 20addcli 11152 . . . 4 (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵)) ∈ ℂ
2217, 18, 21add32i 11371 . . 3 ((((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (𝐷 · 𝐵)) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))) = ((((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))) + (𝐷 · 𝐵))
238, 12mulcli 11153 . . . . . 6 ((𝐴 · (10↑𝑀)) · 𝐶) ∈ ℂ
24 karatsuba.s . . . . . . 7 𝑆 ∈ ℕ0
2524nn0cni 12427 . . . . . 6 𝑆 ∈ ℂ
2623, 25, 7adddiri 11159 . . . . 5 ((((𝐴 · (10↑𝑀)) · 𝐶) + 𝑆) · (10↑𝑀)) = ((((𝐴 · (10↑𝑀)) · 𝐶) · (10↑𝑀)) + (𝑆 · (10↑𝑀)))
272, 7, 12mul32i 11343 . . . . . . . . 9 ((𝐴 · (10↑𝑀)) · 𝐶) = ((𝐴 · 𝐶) · (10↑𝑀))
28 karatsuba.r . . . . . . . . . 10 (𝐴 · 𝐶) = 𝑅
2928oveq1i 7380 . . . . . . . . 9 ((𝐴 · 𝐶) · (10↑𝑀)) = (𝑅 · (10↑𝑀))
3027, 29eqtri 2760 . . . . . . . 8 ((𝐴 · (10↑𝑀)) · 𝐶) = (𝑅 · (10↑𝑀))
3130oveq1i 7380 . . . . . . 7 (((𝐴 · (10↑𝑀)) · 𝐶) + 𝑆) = ((𝑅 · (10↑𝑀)) + 𝑆)
32 karatsuba.w . . . . . . 7 ((𝑅 · (10↑𝑀)) + 𝑆) = 𝑊
3331, 32eqtri 2760 . . . . . 6 (((𝐴 · (10↑𝑀)) · 𝐶) + 𝑆) = 𝑊
3433oveq1i 7380 . . . . 5 ((((𝐴 · (10↑𝑀)) · 𝐶) + 𝑆) · (10↑𝑀)) = (𝑊 · (10↑𝑀))
358, 12, 7mulassi 11157 . . . . . 6 (((𝐴 · (10↑𝑀)) · 𝐶) · (10↑𝑀)) = ((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀)))
362, 12mulcli 11153 . . . . . . . . . . . 12 (𝐴 · 𝐶) ∈ ℂ
3736, 18, 25add32i 11371 . . . . . . . . . . 11 (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + 𝑆) = (((𝐴 · 𝐶) + 𝑆) + (𝐷 · 𝐵))
3828oveq1i 7380 . . . . . . . . . . . 12 ((𝐴 · 𝐶) + 𝑆) = (𝑅 + 𝑆)
39 karatsuba.t . . . . . . . . . . . . 13 (𝐵 · 𝐷) = 𝑇
4010, 15, 39mulcomli 11155 . . . . . . . . . . . 12 (𝐷 · 𝐵) = 𝑇
4138, 40oveq12i 7382 . . . . . . . . . . 11 (((𝐴 · 𝐶) + 𝑆) + (𝐷 · 𝐵)) = ((𝑅 + 𝑆) + 𝑇)
4237, 41eqtri 2760 . . . . . . . . . 10 (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + 𝑆) = ((𝑅 + 𝑆) + 𝑇)
43 karatsuba.e . . . . . . . . . 10 ((𝐴 + 𝐵) · (𝐶 + 𝐷)) = ((𝑅 + 𝑆) + 𝑇)
442, 10, 12, 15muladdi 11602 . . . . . . . . . 10 ((𝐴 + 𝐵) · (𝐶 + 𝐷)) = (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + ((𝐴 · 𝐷) + (𝐶 · 𝐵)))
4542, 43, 443eqtr2i 2766 . . . . . . . . 9 (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + 𝑆) = (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + ((𝐴 · 𝐷) + (𝐶 · 𝐵)))
4636, 18addcli 11152 . . . . . . . . . 10 ((𝐴 · 𝐶) + (𝐷 · 𝐵)) ∈ ℂ
472, 15mulcli 11153 . . . . . . . . . . 11 (𝐴 · 𝐷) ∈ ℂ
4812, 10mulcli 11153 . . . . . . . . . . 11 (𝐶 · 𝐵) ∈ ℂ
4947, 48addcli 11152 . . . . . . . . . 10 ((𝐴 · 𝐷) + (𝐶 · 𝐵)) ∈ ℂ
5046, 25, 49addcani 11340 . . . . . . . . 9 ((((𝐴 · 𝐶) + (𝐷 · 𝐵)) + 𝑆) = (((𝐴 · 𝐶) + (𝐷 · 𝐵)) + ((𝐴 · 𝐷) + (𝐶 · 𝐵))) ↔ 𝑆 = ((𝐴 · 𝐷) + (𝐶 · 𝐵)))
5145, 50mpbi 230 . . . . . . . 8 𝑆 = ((𝐴 · 𝐷) + (𝐶 · 𝐵))
5251oveq1i 7380 . . . . . . 7 (𝑆 · (10↑𝑀)) = (((𝐴 · 𝐷) + (𝐶 · 𝐵)) · (10↑𝑀))
5347, 48, 7adddiri 11159 . . . . . . 7 (((𝐴 · 𝐷) + (𝐶 · 𝐵)) · (10↑𝑀)) = (((𝐴 · 𝐷) · (10↑𝑀)) + ((𝐶 · 𝐵) · (10↑𝑀)))
542, 15, 7mul32i 11343 . . . . . . . 8 ((𝐴 · 𝐷) · (10↑𝑀)) = ((𝐴 · (10↑𝑀)) · 𝐷)
5512, 10, 7mul32i 11343 . . . . . . . 8 ((𝐶 · 𝐵) · (10↑𝑀)) = ((𝐶 · (10↑𝑀)) · 𝐵)
5654, 55oveq12i 7382 . . . . . . 7 (((𝐴 · 𝐷) · (10↑𝑀)) + ((𝐶 · 𝐵) · (10↑𝑀))) = (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))
5752, 53, 563eqtri 2764 . . . . . 6 (𝑆 · (10↑𝑀)) = (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))
5835, 57oveq12i 7382 . . . . 5 ((((𝐴 · (10↑𝑀)) · 𝐶) · (10↑𝑀)) + (𝑆 · (10↑𝑀))) = (((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵)))
5926, 34, 583eqtr3ri 2769 . . . 4 (((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))) = (𝑊 · (10↑𝑀))
6059, 40oveq12i 7382 . . 3 ((((𝐴 · (10↑𝑀)) · (𝐶 · (10↑𝑀))) + (((𝐴 · (10↑𝑀)) · 𝐷) + ((𝐶 · (10↑𝑀)) · 𝐵))) + (𝐷 · 𝐵)) = ((𝑊 · (10↑𝑀)) + 𝑇)
6116, 22, 603eqtri 2764 . 2 (((𝐴 · (10↑𝑀)) + 𝐵) · ((𝐶 · (10↑𝑀)) + 𝐷)) = ((𝑊 · (10↑𝑀)) + 𝑇)
62 karatsuba.x . . 3 ((𝐴 · (10↑𝑀)) + 𝐵) = 𝑋
63 karatsuba.y . . 3 ((𝐶 · (10↑𝑀)) + 𝐷) = 𝑌
6462, 63oveq12i 7382 . 2 (((𝐴 · (10↑𝑀)) + 𝐵) · ((𝐶 · (10↑𝑀)) + 𝐷)) = (𝑋 · 𝑌)
65 karatsuba.z . 2 ((𝑊 · (10↑𝑀)) + 𝑇) = 𝑍
6661, 64, 653eqtr3i 2768 1 (𝑋 · 𝑌) = 𝑍
Colors of variables: wff setvar class
Syntax hints:   = wceq 1542  wcel 2114  (class class class)co 7370  cc 11038  0cc0 11040  1c1 11041   + caddc 11043   · cmul 11045  0cn0 12415  cdc 12621  cexp 13998
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 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-sep 5245  ax-nul 5255  ax-pow 5314  ax-pr 5381  ax-un 7692  ax-cnex 11096  ax-resscn 11097  ax-1cn 11098  ax-icn 11099  ax-addcl 11100  ax-addrcl 11101  ax-mulcl 11102  ax-mulrcl 11103  ax-mulcom 11104  ax-addass 11105  ax-mulass 11106  ax-distr 11107  ax-i2m1 11108  ax-1ne0 11109  ax-1rid 11110  ax-rnegex 11111  ax-rrecex 11112  ax-cnre 11113  ax-pre-lttri 11114  ax-pre-lttrn 11115  ax-pre-ltadd 11116  ax-pre-mulgt0 11117
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3063  df-reu 3353  df-rab 3402  df-v 3444  df-sbc 3743  df-csb 3852  df-dif 3906  df-un 3908  df-in 3910  df-ss 3920  df-pss 3923  df-nul 4288  df-if 4482  df-pw 4558  df-sn 4583  df-pr 4585  df-op 4589  df-uni 4866  df-iun 4950  df-br 5101  df-opab 5163  df-mpt 5182  df-tr 5208  df-id 5529  df-eprel 5534  df-po 5542  df-so 5543  df-fr 5587  df-we 5589  df-xp 5640  df-rel 5641  df-cnv 5642  df-co 5643  df-dm 5644  df-rn 5645  df-res 5646  df-ima 5647  df-pred 6269  df-ord 6330  df-on 6331  df-lim 6332  df-suc 6333  df-iota 6458  df-fun 6504  df-fn 6505  df-f 6506  df-f1 6507  df-fo 6508  df-f1o 6509  df-fv 6510  df-riota 7327  df-ov 7373  df-oprab 7374  df-mpo 7375  df-om 7821  df-2nd 7946  df-frecs 8235  df-wrecs 8266  df-recs 8315  df-rdg 8353  df-er 8647  df-en 8898  df-dom 8899  df-sdom 8900  df-pnf 11182  df-mnf 11183  df-xr 11184  df-ltxr 11185  df-le 11186  df-sub 11380  df-neg 11381  df-nn 12160  df-2 12222  df-3 12223  df-4 12224  df-5 12225  df-6 12226  df-7 12227  df-8 12228  df-9 12229  df-n0 12416  df-z 12503  df-dec 12622  df-uz 12766  df-seq 13939  df-exp 13999
This theorem is referenced by:  dpmul4  33012
  Copyright terms: Public domain W3C validator