Available:*
Library | Item Barcode | Call Number | Material Type | Item Category 1 | Status |
---|---|---|---|---|---|
Searching... | 30000010297423 | QA76.642 F86 2012 | Open Access Book | Book | Searching... |
On Order
Summary
Summary
With multicore processors now in every computer, server, and embedded device, the need for cost-effective, reliable parallel software has never been greater. By explaining key aspects of multicore programming, Fundamentals of Multicore Software Development helps software engineers understand parallel programming and master the multicore challenge.
Accessible to newcomers to the field, the book captures the state of the art of multicore programming in computer science. It covers the fundamentals of multicore hardware, parallel design patterns, and parallel programming in C++, .NET, and Java. It also discusses manycore computing on graphics cards and heterogeneous multicore platforms, automatic parallelization, automatic performance tuning, transactional memory, and emerging applications.
As computing power increasingly comes from parallelism, software developers must embrace parallel programming. Written by leaders in the field, this book provides an overview of the existing and up-and-coming programming choices for multicores. It addresses issues in systems architecture, operating systems, languages, and compilers.
Author Notes
Victor Pankratius heads the Multicore Software Engineering group at the Karlsruhe Institute of Technology. He is also the elected chairman of the Software Engineering for Parallel Systems (SEPARS) international working group. With a focus on making parallel programming easier, his research encompasses auto-tuning, language design, debugging, and empirical studies.
Ali-Reza Adl-Tabatabai is a senior principal engineer at Intel Corporation, where he leads a team working on compilers and scalable runtimes. His research concentrates on language features that make it easier to build reliable and scalable parallel programs for future multicore architectures.
Walter Tichy is a professor of computer science and head of the Programming Systems group at the Karlsruhe Institute of Technology. He is also a member of the board of directors of software engineering at Forschungszentrum Informatik (FZI), an independent research institution. His research covers tools and methods to simplify the engineering of general-purpose parallel software, including race detection, auto-tuning, and high-level languages for expressing parallelism.
Table of Contents
Foreword | p. vii |
Editors | p. ix |
Contributors | p. xi |
1 Introduction | p. 1 |
Part I Basics of Parallel Programming | p. 7 |
2 Fundamentals of Multicore Hardware and Parallel Programming | p. 9 |
3 Parallel Design Patterns | p. 31 |
Part II Programming Languages for Multicore | p. 53 |
4 Threads and Shared Variables in C++ | p. 55 |
5 Parallelism in .NET and Java | p. 79 |
6 OpenMP | p. 101 |
Part III Programming Heterogeneous Processors | p. 129 |
7 Scalable Manycore Computing with CUDA | p. 131 |
8 Programming the Cell Processor | p. 155 |
Part IV Emerging Technologies | p. 199 |
9 Automatic Extraction of Parallelism from Sequential Code | p. 201 |
10 Auto-Tuning Parallel Application Performance | p. 239 |
11 Transactional Memory | p. 265 |
12 Emerging Applications | p. 291 |
Index | p. 309 |