Mesin Akses Acak Paralel
Parallel Random Access Machines (PRAM)adalah model, yang dianggap untuk sebagian besar algoritme paralel. Di sini, beberapa prosesor dipasang ke satu blok memori. Model PRAM berisi -
Seperangkat prosesor sejenis.
Semua prosesor berbagi unit memori yang sama. Prosesor dapat berkomunikasi di antara mereka sendiri hanya melalui memori bersama.
Unit akses memori (MAU) menghubungkan prosesor dengan satu memori bersama.
Sini, n jumlah prosesor dapat melakukan operasi independen njumlah data dalam satuan waktu tertentu. Ini dapat mengakibatkan akses simultan dari lokasi memori yang sama oleh prosesor yang berbeda.
Untuk mengatasi masalah ini, kendala berikut telah diterapkan pada model PRAM -
Exclusive Read Exclusive Write (EREW) - Di sini tidak ada dua prosesor yang diizinkan untuk membaca atau menulis ke lokasi memori yang sama pada waktu yang sama.
Exclusive Read Concurrent Write (ERCW) - Di sini tidak ada dua prosesor yang diizinkan untuk membaca dari lokasi memori yang sama pada waktu yang sama, tetapi diizinkan untuk menulis ke lokasi memori yang sama pada waktu yang sama.
Concurrent Read Exclusive Write (CREW) - Di sini semua prosesor diizinkan untuk membaca dari lokasi memori yang sama pada waktu yang sama, tetapi tidak diizinkan untuk menulis ke lokasi memori yang sama pada waktu yang sama.
Concurrent Read Concurrent Write (CRCW) - Semua prosesor diizinkan untuk membaca atau menulis ke lokasi memori yang sama pada waktu yang sama.
Ada banyak metode untuk mengimplementasikan model PRAM, tetapi yang paling menonjol adalah -
- Model memori bersama
- Model pengiriman pesan
- Model paralel data
Model Memori Bersama
Memori bersama menekankan pada control parallelism dari pada data parallelism. Dalam model memori bersama, beberapa proses dijalankan pada prosesor yang berbeda secara independen, tetapi mereka berbagi ruang memori yang sama. Karena aktivitas prosesor apa pun, jika ada perubahan apa pun di lokasi memori apa pun, itu terlihat oleh prosesor lainnya.
Karena beberapa prosesor mengakses lokasi memori yang sama, mungkin saja terjadi pada titik waktu tertentu, lebih dari satu prosesor mengakses lokasi memori yang sama. Misalkan yang satu membaca lokasi itu dan yang lainnya sedang menulis di lokasi itu. Ini dapat menimbulkan kebingungan. Untuk menghindari hal ini, beberapa mekanisme kontrol, sepertilock / semaphore, diterapkan untuk memastikan saling pengecualian.
Pemrograman memori bersama telah diimplementasikan sebagai berikut -
Thread libraries- Pustaka utas memungkinkan beberapa utas kontrol yang berjalan secara bersamaan di lokasi memori yang sama. Pustaka utas menyediakan antarmuka yang mendukung multithreading melalui pustaka subrutin. Ini berisi subrutin untuk
- Membuat dan menghancurkan utas
- Menjadwalkan eksekusi utas
- melewatkan data dan pesan antar utas
- menyimpan dan memulihkan konteks utas
Contoh pustaka utas meliputi - utas SolarisTM untuk Solaris, utas POSIX seperti yang diterapkan di Linux, utas Win32 tersedia di Windows NT dan Windows 2000, dan utas JavaTM sebagai bagian dari JavaTM Development Kit (JDK) standar.
Distributed Shared Memory (DSM) Systems- Sistem DSM membuat abstraksi memori bersama pada arsitektur yang digabungkan secara longgar untuk mengimplementasikan pemrograman memori bersama tanpa dukungan perangkat keras. Mereka menerapkan pustaka standar dan menggunakan fitur manajemen memori tingkat pengguna lanjutan yang ada dalam sistem operasi modern. Contohnya termasuk Tread Marks System, Munin, IVY, Shasta, Brazos, dan Cashmere.
Program Annotation Packages- Ini diterapkan pada arsitektur yang memiliki karakteristik akses memori yang seragam. Contoh paling terkenal dari paket anotasi program adalah OpenMP. OpenMP mengimplementasikan paralelisme fungsional. Ini terutama berfokus pada paralelisasi loop.
Konsep memori bersama menyediakan kontrol tingkat rendah dari sistem memori bersama, tetapi cenderung membosankan dan keliru. Ini lebih dapat diterapkan untuk pemrograman sistem daripada pemrograman aplikasi.
Manfaat Pemrograman Memori Bersama
Ruang alamat global memberikan pendekatan pemrograman yang mudah digunakan untuk memori.
Karena kedekatan memori dengan CPU, berbagi data antar proses menjadi cepat dan seragam.
Tidak perlu secara khusus menjelaskan komunikasi data antar proses.
Overhead proses-komunikasi dapat diabaikan.
Sangat mudah dipelajari.
Kekurangan Pemrograman Memori Bersama
- Ini tidak portabel.
- Mengelola lokalitas data sangat sulit.
Model Penerusan Pesan
Pengiriman pesan adalah pendekatan pemrograman paralel yang paling umum digunakan dalam sistem memori terdistribusi. Di sini, programmer harus menentukan paralelisme. Dalam model ini, semua prosesor memiliki unit memori lokalnya sendiri dan mereka bertukar data melalui jaringan komunikasi.
Prosesor menggunakan pustaka penyampaian pesan untuk komunikasi di antara mereka sendiri. Seiring dengan data yang dikirim, pesan tersebut berisi komponen berikut -
Alamat prosesor yang mengirim pesan;
Alamat awal dari lokasi memori data di prosesor pengirim;
Jenis data dari data pengiriman;
Ukuran data dari pengiriman data;
Alamat prosesor yang menjadi tujuan pengiriman pesan;
Alamat awal dari lokasi memori untuk data di prosesor penerima.
Prosesor dapat berkomunikasi satu sama lain dengan salah satu metode berikut -
- Komunikasi Point-to-Point
- Komunikasi Kolektif
- Antarmuka Penerusan Pesan
Komunikasi Point-to-Point
Komunikasi titik-ke-titik adalah bentuk penyampaian pesan yang paling sederhana. Di sini, pesan dapat dikirim dari prosesor pengirim ke prosesor penerima dengan salah satu mode transfer berikut -
Synchronous mode - Pesan berikutnya dikirim hanya setelah menerima konfirmasi bahwa pesan sebelumnya telah terkirim, untuk mempertahankan urutan pesan.
Asynchronous mode - Untuk mengirim pesan berikutnya, tidak diperlukan penerimaan konfirmasi pengiriman pesan sebelumnya.
Komunikasi Kolektif
Komunikasi kolektif melibatkan lebih dari dua prosesor untuk penyampaian pesan. Mode berikut memungkinkan komunikasi kolektif -
Barrier - Mode penghalang dimungkinkan jika semua prosesor yang termasuk dalam komunikasi menjalankan bock tertentu (dikenal sebagai barrier block) untuk penyampaian pesan.
Broadcast - Penyiaran terdiri dari dua jenis -
One-to-all - Di sini, satu prosesor dengan satu operasi mengirimkan pesan yang sama ke semua prosesor lainnya.
All-to-all - Di sini, semua prosesor mengirim pesan ke semua prosesor lainnya.
Pesan yang disiarkan mungkin dari tiga jenis -
Personalized - Pesan unik dikirim ke semua prosesor tujuan lainnya.
Non-personalized - Semua prosesor tujuan menerima pesan yang sama.
Reduction - Dalam penyiaran reduksi, satu prosesor grup mengumpulkan semua pesan dari semua prosesor lain dalam grup dan menggabungkannya menjadi satu pesan yang dapat diakses oleh semua prosesor lain dalam grup.
Manfaat Pengiriman Pesan
- Memberikan kontrol paralelisme tingkat rendah;
- Ini portabel;
- Lebih sedikit rawan kesalahan;
- Lebih sedikit overhead dalam sinkronisasi paralel dan distribusi data.
Kekurangan Penyampaian Pesan
Dibandingkan dengan kode memori bersama paralel, kode penyampaian pesan umumnya membutuhkan lebih banyak biaya perangkat lunak.
Perpustakaan yang Melewati Pesan
Ada banyak perpustakaan penyampaian pesan. Di sini, kita akan membahas dua pustaka penyampaian pesan yang paling banyak digunakan -
- Message Passing Interface (MPI)
- Mesin Virtual Paralel (PVM)
Message Passing Interface (MPI)
Ini adalah standar universal untuk menyediakan komunikasi di antara semua proses bersamaan dalam sistem memori terdistribusi. Sebagian besar platform komputasi paralel yang umum digunakan menyediakan setidaknya satu implementasi antarmuka penyampaian pesan. Ini telah diimplementasikan sebagai kumpulan fungsi yang telah ditentukan sebelumnya yang disebutlibrary dan dapat dipanggil dari bahasa seperti C, C ++, Fortran, dll. MPI cepat dan portabel dibandingkan dengan pustaka penyampaian pesan lainnya.
Merits of Message Passing Interface
Berjalan hanya pada arsitektur memori bersama atau arsitektur memori terdistribusi;
Setiap prosesor memiliki variabel lokalnya sendiri;
Dibandingkan dengan komputer memori bersama yang besar, komputer memori terdistribusi lebih murah.
Demerits of Message Passing Interface
- Lebih banyak perubahan pemrograman diperlukan untuk algoritma paralel;
- Terkadang sulit untuk di-debug; dan
- Tidak bekerja dengan baik dalam jaringan komunikasi antar node.
Mesin Virtual Paralel (PVM)
PVM adalah sistem penyampaian pesan portabel, yang dirancang untuk menghubungkan mesin host heterogen yang terpisah untuk membentuk satu mesin virtual. Ini adalah sumber daya komputasi paralel tunggal yang dapat dikelola. Masalah komputasi yang besar seperti studi superkonduktivitas, simulasi dinamika molekuler, dan algoritme matriks dapat diselesaikan dengan biaya lebih efektif dengan menggunakan memori dan daya agregat dari banyak komputer. Ia mengatur semua perutean pesan, konversi data, penjadwalan tugas di jaringan arsitektur komputer yang tidak kompatibel.
Features of PVM
- Sangat mudah dipasang dan dikonfigurasi;
- Beberapa pengguna dapat menggunakan PVM secara bersamaan;
- Satu pengguna dapat menjalankan banyak aplikasi;
- Ini adalah paket kecil;
- Mendukung C, C ++, Fortran;
- Untuk menjalankan program PVM tertentu, pengguna dapat memilih grup mesin;
- Ini adalah model penyampaian pesan,
- Perhitungan berbasis proses;
- Mendukung arsitektur heterogen.
Pemrograman Data Paralel
Fokus utama dari model pemrograman data paralel adalah melakukan operasi pada kumpulan data secara bersamaan. Kumpulan data diatur ke dalam beberapa struktur seperti array, hypercube, dll. Prosesor melakukan operasi secara kolektif pada struktur data yang sama. Setiap tugas dilakukan pada partisi berbeda dari struktur data yang sama.
Ini membatasi, karena tidak semua algoritme dapat ditentukan dalam istilah paralelisme data. Inilah alasan mengapa paralelisme data tidak universal.
Bahasa paralel data membantu menentukan dekomposisi data dan pemetaan ke prosesor. Ini juga mencakup pernyataan distribusi data yang memungkinkan pemrogram memiliki kendali atas data - misalnya, data mana yang akan pergi ke prosesor mana - untuk mengurangi jumlah komunikasi di dalam prosesor.