TAILIEUCHUNG - Parallel Programming: for Multicore and Cluster Systems- P28

Parallel Programming: for Multicore and Cluster Systems- P28: Innovations in hardware architecture, like hyper-threading or multicore processors, mean that parallel computing resources are available for inexpensive desktop computers. In only a few years, many standard software products will be based on concepts of parallel programming implemented on such hardware, and the range of applications will be much broader than that of scientific computing, up to now the main application area for parallel computing | 262 6 Thread Programming include typedef struct int size row column double MA 8 MB 8 MC 8 matrix_type_t void thread_mult void w matrix_type_t work matrix-type_t w int i row work- row column work- column work - MC row column 0 for i 0 i work- size i work- MC row column work- MA row i work- MB i column return NULL int main int row column size 8 i double MA 8 8 MB 8 8 MC 8 8 matrix_type_t work pthread_t thread 8 8 for row 0 row size row for column 0 column size column work matrix_type_t malloc sizeof matrix_type_t work- size size work- row row work- column column work- MA MA work- MB MB work- MC MC pthread_create thread column row 8 NULL thread_mult void work for i 0 i size size i pthread_join thread i NULL Fig. Pthreads program for the multiplication of two matrices MA and MB. A separate thread is created for each element of the output matrix MC. A separate data structure work is provided for each of the threads created been set into a detached state calling pthread_join for this thread returns the error value EINVAL. Example We give a first example for a Pthreads program Fig. shows a program fragment for the multiplication of two matrices see also 126 . The matrices MA and MB to be multiplied have a fixed size of eight rows and eight columns. For each of the elements of the result matrix MC a separate thread is created. The IDs of these threads are stored in the array thread. Each thread obtains a separate data structure of type matrix_type_t which contains pointers to the input matrices MA and MB the output matrix MC and the row and column position of the entry of MC to be computed by the corresponding thread. Each thread executes the same thread function thread_mult which computes the scalar product of one row of MA and one column of MB. After creating a new thread for each of the 64 elements Programming with Pthreads 263 of MC to be computed the main thread waits for the termination of each of these threads using pthread_join . The program .

TAILIEUCHUNG - Chia sẻ tài liệu không giới hạn
Địa chỉ : 444 Hoang Hoa Tham, Hanoi, Viet Nam
Website : tailieuchung.com
Email : tailieuchung20@gmail.com
Tailieuchung.com là thư viện tài liệu trực tuyến, nơi chia sẽ trao đổi hàng triệu tài liệu như luận văn đồ án, sách, giáo trình, đề thi.
Chúng tôi không chịu trách nhiệm liên quan đến các vấn đề bản quyền nội dung tài liệu được thành viên tự nguyện đăng tải lên, nếu phát hiện thấy tài liệu xấu hoặc tài liệu có bản quyền xin hãy email cho chúng tôi.
Đã phát hiện trình chặn quảng cáo AdBlock
Trang web này phụ thuộc vào doanh thu từ số lần hiển thị quảng cáo để tồn tại. Vui lòng tắt trình chặn quảng cáo của bạn hoặc tạm dừng tính năng chặn quảng cáo cho trang web này.