Algoritma Paralel - Pendahuluan
Sebuah algorithmmerupakan urutan langkah-langkah yang mengambil masukan dari pengguna dan setelah dilakukan beberapa komputasi menghasilkan keluaran. SEBUAHparallel algorithm adalah algoritma yang dapat menjalankan beberapa instruksi secara bersamaan pada perangkat pemrosesan yang berbeda dan kemudian menggabungkan semua keluaran individu untuk menghasilkan hasil akhir.
Pemrosesan Bersamaan
Ketersediaan komputer yang mudah seiring dengan pertumbuhan internet telah mengubah cara kita menyimpan dan memproses data. Kita hidup di zaman di mana data tersedia dengan berlimpah. Setiap hari kami berurusan dengan volume data yang sangat besar yang membutuhkan komputasi kompleks dan itu juga, dalam waktu cepat. Terkadang, kita perlu mengambil data dari peristiwa serupa atau saling terkait yang terjadi secara bersamaan. Di sinilah kita membutuhkanconcurrent processing yang dapat membagi tugas kompleks dan memprosesnya beberapa sistem untuk menghasilkan keluaran dalam waktu cepat.
Pemrosesan serentak sangat penting ketika tugas melibatkan pemrosesan sejumlah besar data kompleks. Contohnya termasuk - mengakses database besar, pengujian pesawat terbang, perhitungan astronomi, fisika atom dan nuklir, analisis biomedis, perencanaan ekonomi, pemrosesan gambar, robotika, prakiraan cuaca, layanan berbasis web, dll.
Apa itu Paralelisme?
Parallelismadalah proses memproses beberapa set instruksi secara bersamaan. Ini mengurangi total waktu komputasi. Paralelisme dapat diimplementasikan dengan menggunakanparallel computers,yaitu komputer dengan banyak prosesor. Komputer paralel membutuhkan algoritma paralel, bahasa pemrograman, kompiler dan sistem operasi yang mendukung multitasking.
Dalam tutorial ini, kita hanya akan membahas tentang parallel algorithms. Sebelum melangkah lebih jauh, mari kita bahas dulu tentang algoritma dan tipenya.
Apa itu Algoritma?
Sebuah algorithmadalah urutan instruksi yang diikuti untuk memecahkan masalah. Saat merancang suatu algoritma, kita harus mempertimbangkan arsitektur komputer tempat algoritma tersebut akan dieksekusi. Sesuai arsitekturnya, ada dua jenis komputer -
- Komputer Berurutan
- Komputer Paralel
Bergantung pada arsitektur komputer, kami memiliki dua jenis algoritme -
Sequential Algorithm - Algoritme di mana beberapa langkah instruksi yang berurutan dijalankan dalam urutan kronologis untuk menyelesaikan masalah.
Parallel Algorithm- Masalah dibagi menjadi sub-masalah dan dijalankan secara paralel untuk mendapatkan keluaran individu. Nanti, keluaran individu ini digabungkan bersama untuk mendapatkan keluaran akhir yang diinginkan.
Tidaklah mudah untuk membagi masalah besar menjadi sub-problems. Sub-masalah mungkin memiliki ketergantungan data di antara mereka. Oleh karena itu, para prosesor harus saling berkomunikasi untuk menyelesaikan masalah tersebut.
Diketahui bahwa waktu yang dibutuhkan oleh prosesor dalam berkomunikasi satu sama lain lebih banyak daripada waktu pemrosesan yang sebenarnya. Jadi, saat mendesain algoritme paralel, penggunaan CPU yang tepat harus dipertimbangkan untuk mendapatkan algoritme yang efisien.
Untuk mendesain algoritme dengan benar, kita harus memiliki ide dasar yang jelas model of computation di komputer paralel.
Model Komputasi
Baik komputer sekuensial dan paralel beroperasi pada sekumpulan (aliran) instruksi yang disebut algoritma. Serangkaian instruksi (algoritme) ini menginstruksikan komputer tentang apa yang harus dilakukannya di setiap langkah.
Bergantung pada aliran instruksi dan aliran data, komputer dapat diklasifikasikan menjadi empat kategori -
- Aliran instruksi tunggal, aliran data tunggal (SISD) komputer
- Aliran Instruksi Tunggal, Aliran Beberapa Data (SIMD) komputer
- Beberapa aliran Instruksi, aliran Data Tunggal (MISD) komputer
- Multiple Instruction stream, Multiple Data stream (MIMD) komputer
Komputer SISD
Komputer SISD berisi one control unit, one processing unit, dan one memory unit.
Dalam jenis komputer ini, prosesor menerima aliran instruksi tunggal dari unit kontrol dan beroperasi pada aliran data tunggal dari unit memori. Selama komputasi, pada setiap langkah, prosesor menerima satu instruksi dari unit kontrol dan beroperasi pada satu data yang diterima dari unit memori.
Komputer SIMD
Komputer SIMD berisi one control unit, multiple processing units, dan shared memory or interconnection network.
Di sini, satu unit kontrol tunggal mengirimkan instruksi ke semua unit pemrosesan. Selama komputasi, pada setiap langkah, semua prosesor menerima satu set instruksi dari unit kontrol dan beroperasi pada kumpulan data yang berbeda dari unit memori.
Setiap unit pemrosesan memiliki unit memori lokalnya sendiri untuk menyimpan data dan instruksi. Di komputer SIMD, prosesor perlu berkomunikasi di antara mereka sendiri. Ini dilakukan olehshared memory atau oleh interconnection network.
Sementara beberapa prosesor menjalankan serangkaian instruksi, prosesor yang tersisa menunggu rangkaian instruksi berikutnya. Instruksi dari unit kontrol memutuskan prosesor mana yang akan digunakanactive (jalankan instruksi) atau inactive (tunggu instruksi selanjutnya).
Komputer MISD
Seperti namanya, komputer MISD mengandung multiple control units, multiple processing units, dan one common memory unit.
Di sini, setiap prosesor memiliki unit kontrolnya sendiri dan mereka berbagi unit memori yang sama. Semua prosesor mendapatkan instruksi secara individual dari unit kontrol mereka sendiri dan mereka beroperasi pada aliran data tunggal sesuai instruksi yang mereka terima dari unit kontrol masing-masing. Prosesor ini beroperasi secara bersamaan.
Komputer MIMD
Komputer MIMD memiliki multiple control units, multiple processing units, dan a shared memory atau interconnection network.
Di sini, setiap prosesor memiliki unit kontrolnya sendiri, unit memori lokal, dan unit aritmatika dan logika. Mereka menerima set instruksi yang berbeda dari unit kontrol masing-masing dan beroperasi pada set data yang berbeda.
Catatan
Komputer MIMD yang berbagi memori yang sama dikenal sebagai multiprocessors, sedangkan yang menggunakan jaringan interkoneksi disebut multicomputers.
Berdasarkan jarak fisik prosesor, multikomputer terdiri dari dua jenis -
Multicomputer - Ketika semua prosesor sangat dekat satu sama lain (misalnya, di ruangan yang sama).
Distributed system - Ketika semua prosesor berada jauh dari satu sama lain (misalnya - di kota yang berbeda)