Data Parallel C++ Data Parallel C++

Data Parallel C+‪+‬

Mastering DPC++ for Programming of Heterogeneous Systems using C++ and SYCL

James Reinders والمزيد
    • ٥٫٠ - ١ تقييم

وصف الناشر

Learn how to accelerate C++ programs using data parallelism.

Data parallelism in C++ enables access to parallel resources in a modern heterogeneous system, freeing you from being locked into any particular computing device. Now a single C++ application can use any combination of devices—including GPUs, CPUs, FPGAs and AI ASICs—that are suitable to the problems at hand.

This open access book enables C++ programmers to be at the forefront of this exciting and important new development that is helping to push computing to new levels. It is full of practical advice, detailed explanations, and code examples to illustrate key topics.

This book teaches data-parallel programming using C++ and the SYCL standard from the Khronos Group and walks through everything needed to use SYCL for programming heterogeneous systems.  The book begins by introducing data parallelism and foundational topics for effective use of SYCL and Data Parallel C++ (DPC++), the open source compiler used in this book. Later chapters cover advanced topics including error handling, hardware-specific programming, communication and synchronization, and memory model considerations.

You will learn:

• How to accelerate C++ programs using data-parallel programming

• How to target multiple device types (e.g. CPU, GPU, FPGA)

• How to use SYCL and SYCL compilers

• How to connect with computing’s heterogeneous future via Intel’s oneAPI initiative

النوع
كمبيوتر وإنترنت
تاريخ النشر
٢٠٢٠
٢ نوفمبر
اللغة
EN
الإنجليزية
عدد الصفحات
٥٧٤
الناشر
Apress
البائع
Springer Nature B.V.
الحجم
٨٧٫٣
‫م.ب.‬
The Elements of Computing Systems, second edition The Elements of Computing Systems, second edition
٢٠٢١
Systems Performance Systems Performance
٢٠٢٠
Rust in Action Rust in Action
٢٠٢١
Programming with 64-Bit ARM Assembly Language Programming with 64-Bit ARM Assembly Language
٢٠٢٠
Linux Kernel Programming Part 2 - Char Device Drivers and Kernel Synchronization Linux Kernel Programming Part 2 - Char Device Drivers and Kernel Synchronization
٢٠٢١
The Beauty of Computation The Beauty of Computation
٢٠١٣
Pro TBB Pro TBB
٢٠١٩
Data Parallel C++ Data Parallel C++
٢٠٢٣
Intel Threading Building Blocks Intel Threading Building Blocks
٢٠٠٧
Structured Parallel Programming Structured Parallel Programming
٢٠١٢
Intel Xeon Phi Coprocessor High Performance Programming Intel Xeon Phi Coprocessor High Performance Programming
٢٠١٣
Multithreading for Visual Effects Multithreading for Visual Effects
٢٠١٤
Microservices from Theory to Practice: Creating Applications in IBM Bluemix Using the Microservices Approach Microservices from Theory to Practice: Creating Applications in IBM Bluemix Using the Microservices Approach
٢٠١٦
Conceptive C Conceptive C
٢٠١١
Security in Computer and Information Sciences Security in Computer and Information Sciences
٢٠١٨
Embedded System Design Embedded System Design
٢٠٢١
Probability in Electrical Engineering and Computer Science Probability in Electrical Engineering and Computer Science
٢٠٢١
Lessons on development of 64-bit C/C++ applications Lessons on development of 64-bit C/C++ applications
٢٠١٢