Berikut contoh visual dari metode yang diajarkan di sekolah untuk mengalikan angka desimal didasarkan pada perhitungan hasil perkalian parsial, menggesernya ke kiri, lalu menjumlahkannya. Bagian yang paling sulit adalah memperoleh hasil perkalian parsial, karena hal itu melibatkan perkalian angka panjang dengan satu digit (dari 0 hingga 9):
123
× 456
=====
738 (ini adalah 123 × 6)
615 (ini adalah 123 × 5, digeser satu posisi ke kiri)
+ 492 (ini adalah 123 × 4, digeser dua posisi ke kiri)
=====
56088
Komputer biner melakukan perkalian yang sama persis seperti yang dilakukan angka desimal, tetapi dengan menggunakan bilangan biner berbasis 2. Dalam pengodean biner, setiap angka panjang dikalikan dengan satu digit (baik 0 atau 1), dan itu jauh lebih mudah daripada dalam desimal, karena hasil perkalian dengan 0 atau 1 hanya menghasilkan 0 atau angka yang sama, 0 atau 1. Oleh karena itu, perkalian dua angka biner menghasilkan perhitungan hasil perkalian parsial (yaitu 0 atau angka pertama), menggesernya ke kiri, lalu menjumlahkannya (tentu dengan penjumlahan biner):
1011 (ini adalah biner yang setara dengan 11 pada bilangan desimal)
× 1110 (ini adalah biner yang setara dengan 14 pada bilangan desimal)
======
0000 (ini adalah 1011 × 0)
1011 (ini adalah 1011 × 1, digeser satu posisi ke kiri)
1011 (ini adalah 1011 × 1, digeser dua posisi ke kiri)
+ 1011 (ini adalah 1011 × 1, digeser tiga posisi ke kiri)
=========
10011010 (ini adalah biner untuk desimal 154)
Ini jauh lebih sederhana dibandingkan sistem desimal, karena tidak ada tabel perkalian yang perlu diingat: hanya pergeseran dan penjumlahan.
Metode ini secara matematis benar dan memiliki keuntungan bahwa CPU kecil dapat melakukan perkalian dengan menggunakan fitur shift dan add dari unit logika aritmatikanya daripada sirkuit khusus. Namun, metode ini lambat karena melibatkan banyak penjumlahan antara. Penjumlahan ini memakan waktu. Pengganda yang lebih cepat dapat direkayasa untuk melakukan penjumlahan yang lebih sedikit; prosesor modern dapat mengalikan dua angka 64-bit dengan 6 penjumlahan (daripada 64), dan dapat melakukan beberapa langkah secara paralel. [butuh rujukan]
Masalah kedua adalah bahwa metode sekolah dasar menangani tanda dengan aturan terpisah ("+ dengan + menghasilkan +", "+ dengan − menghasilkan −", dst.). Komputer modern menyematkan tanda angka di dalam angka itu sendiri, biasanya dalam representasi komplemen dua . Hal itu memaksa proses perkalian untuk disesuaikan guna menangani angka komplemen dua, dan itu sedikit lebih memperumit proses. Demikian pula, prosesor yang menggunakan komplemen satu , tanda dan besaran , IEEE-754 atau representasi biner lainnya memerlukan penyesuaian khusus pada proses perkalian.
Beberapa macam teknik atau cara dapat dipakai untuk merealisasikan operasi perkalian aritmetika ini. Salah satunya adalah dengan mengalikan secara parsiel masing masing bit, kemudian menjumlahkan semua hasil dari perkalian parsiel tersebut. Hal ini mirip dengan proses perkalian bilangan desimal (bilangan basis-10) yang dilakukan oleh murid Sekolah Dasar.
Jika dua buah bilangan biner, a dan b, masing-masing 2 bit (membentuk angka 00, 01, 10, dan 11) dikalikan satu sama lain, maka akan kita peroleh hasil perkalian dalam bentuk bilangan biner 4 bit, seperti tampak pada tabel di bawah ini. Bilangan a ada di kolom paling kiri, dan bilangan b ada di baris paling atas, sementara hasil kalinya ada di dalam masing-masing sel.
Tabel perkalian biner 2-bit:
Informasi lebih lanjut × ...
× | 00 | 01 | 10 | 11 |
00 | 0000 | 0000 | 0000 | 0000 |
01 | 0000 | 0001 | 0010 | 0011 |
10 | 0000 | 0010 | 0100 | 0110 |
11 | 0000 | 0011 | 0110 | 1001 |
Tutup
Cara lain dalam melihat operasi perkalian ini adalah dengan menyatakan bilangan pertama sebagai angka 2 bit a[1] dan a[0], sementara bilangan kedua dinyatakan dengan b[1] dan b[0]. Maka hasil kali parsielnya ada 4 buah: p0[0], p0[1], p1[0], dan p1[1] dengan:
Hasil kali akhir dari bilangan a dan b akan membentuk bilangan P 4 bit: P[3] P[2] P[1] P[0] dengan penjumlahan parsiel sebagai berikut:
Untuk bilangan 8 bit: a[7:0] dan b[7:0], banyaknya hasil kali parsiel juga ada 8 buah:
Hasil akhirnya merupakan penjumlahan dari semua hasil kali parsiel: