Introduction to parallel computing: from algorithms to programming on state-of-the-art platforms
✍ Scribed by Bulić, Patricio; Robič, Borut; Slivnik, Boštjan; Trobec, Roman
- Publisher
- Springer
- Year
- 2018
- Tongue
- English
- Leaves
- 263
- Series
- Undergraduate topics in computer science
- Category
- Library
No coin nor oath required. For personal study only.
✦ Synopsis
Advancements in microprocessor architecture, interconnection technology, and software development have fueled rapid growth in parallel and distributed computing. However, this development is only of practical benefit if it is accompanied by progress in the design, analysis and programming of parallel algorithms. This concise textbook provides, in one place, three mainstream parallelization approaches, Open MPP, MPI Read more...
Abstract: Advancements in microprocessor architecture, interconnection technology, and software development have fueled rapid growth in parallel and distributed computing. However, this development is only of practical benefit if it is accompanied by progress in the design, analysis and programming of parallel algorithms. This concise textbook provides, in one place, three mainstream parallelization approaches, Open MPP, MPI and OpenCL, for multicore computers, interconnected computers and graphical processing units. An overview of practical parallel computing and principles will enable the reader to design efficient parallel programs for solving various computational problems on state-of-the-art personal computers and computing clusters. Topics covered range from parallel algorithms, programming tools, OpenMP, MPI and OpenCL, followed by experimental measurements of parallel programs' run-times, and by engineering analysis of obtained results for improved parallel execution performances. Many examples and exercises support the exposition
✦ Table of Contents
Content: Part I: Foundations --
Why Do We Need Parallel Programming --
Overview of Parallel Systems --
Part II: Programming --
Programming Multi-Core and Shared Memory Multiprocessors Using OpenMP --
MPI Processes and Messaging --
OpenCL for Massively Parallel Graphic Processors --
Part III: Engineering --
Engineering: Parallel Computation of the Number ? --
Engineering: Parallel Solution of 1-D Heat Equation --
Engineering: Parallel Implementation of Seam Carving --
Final Remarks and Perspectives --
Appendix A: Hints for Making Your Computer a Parallel Machine.
✦ Subjects
Parallel programming (Computer science);Parallel processing (Electronic computers);Programming Techniques.;Processor Architectures.;Control Structures and Microprogramming.;Numeric Computing.;Computers -- Systems Architecture -- General.;Computers -- Programming -- Algorithms.;Computer architecture & logic design.;Algorithms & data structures.;Mathematical theory of computation.;Computers -- Programming -- General.;Computer programming -- software development.
📜 SIMILAR VOLUMES
<p><p>Advancements in microprocessor architecture, interconnection technology, and software development have fueled rapid growth in parallel and distributed computing. However, this development is only of practical benefit if it is accompanied by progress in the design, analysis and programming of p
Advancements in microprocessor architecture, interconnection technology, and software development have fueled rapid growth in parallel and distributed computing. However, this development is only of practical benefit if it is accompanied by progress in the design, analysis and programming of paralle
This is the first entry-level book on algorithmic (also known as automatic) differentiation (AD), providing fundamental rules for the generation of first- and higher-order tangent-linear and adjoint code. The author covers the mathematical underpinnings as well as how to apply these observations to