OpenCL Parallel Programming Development Cookbook
暫譯: OpenCL 平行程式設計開發食譜
Raymond Tay
- 出版商: Packt Publishing
- 出版日期: 2013-06-08
- 售價: $2,220
- 貴賓價: 9.5 折 $2,109
- 語言: 英文
- 頁數: 302
- 裝訂: Paperback
- ISBN: 1849694524
- ISBN-13: 9781849694520
-
相關分類:
程式語言
-
相關翻譯:
OpenCL 異構並行程式設計實戰 (簡中版)
海外代購書籍(需單獨結帳)
買這商品的人也買了...
-
$580$458 -
$680$537 -
$780$616 -
$520$411 -
$1,986Programming Computer Vision with Python: Tools and algorithms for analyzing images (Paperback)
-
$580$458 -
$580$458 -
$580$452 -
$940$700 -
$680$537 -
$2,420$2,299 -
$980$774 -
$500$395 -
$650$507 -
$350$277 -
$490$417 -
$860$731 -
$350$315 -
$720$562 -
$520$411 -
$520$411 -
$560$442 -
$1,680$1,596 -
$300$198 -
$5,260$4,997
相關主題
商品描述
This cookbook is the perfect way to learn parallel programming in OpenCL because if offers a mix of enlightening theory and hands-on recipes. Ideal for experienced developers.
Overview
- Learn about parallel programming development in OpenCL and also the various techniques involved in writing high-performing code
- Find out more about data-parallel or task-parallel development and also about the combination of both
- Understand and exploit the underlying hardware features like processor registers and caches that run potentially tens of thousands of threads across the processors
In Detail
OpenCL (Open Computing Language) is the first royalty-free standard for cross platform, parallel programming of modern processors found in personal computers, servers, mobiles, and embedded devices. OpenCL greatly improves speed and responsiveness for a wide spectrum of applications in numerous market categories, from gaming and entertainment to scientific and medical software. OpenCL has proved itself to be versatile in that it now runs on not only operating systems like Windows and Linux powered by Intel and AMD processors, but also on low power chips like ARM, and it has also been adopted by processor manufacturers like ARM Corp, Vivante, and Altera, among others.
OpenCL Parallel Programming Development Cookbook was designed to be practical so that we achieve a good balance between theory and application. Learning to program in a parallel way is relatively easy, but to be able to take advantage of all of the resources available to you efficiently is quite different. You need to be shown not only application, but also the theory behind it.
This book is roughly in two parts, where the first part is the fundamentals of OpenCL parallel development and the second part is the various algorithms we will explore with you. Each part is packed with many code samples and illustrations to demonstrate various concepts. The first part is essential for a beginner to not only program in parallel, but also to think in parallel and become equipped with the mental model with which to tackle parallel programming. The second part consists of seven different algorithms that the author has identified; you will learn various parallel programming techniques that experts have used in the past 60 years that are applicable to OpenCL.
This book will demonstrate how you think in parallel by illustrating and demonstrating programming techniques like data partitioning, thread coarsening, register tiling, data pre-fetching, and algorithm transformation. These techniques are demonstrated in the seven algorithms you’ll be shown, from image processing and solving sparse linear systems to in-memory sorting.
OpenCL Parallel Programming Development Cookbook combines recipes, illustrations, code, and explanations to allow you to learn the essentials of parallel programming in OpenCL, and the author has added in enough math so that the readers understand the motivation and can also lay the foundation upon which they will begin their own exploration.
What you will learn from this book
- How to use OpenCL
- Understand data partitioning and transfers in OpenCL
- Understand OpenCL data types
- Learn about OpenCL functions including math, atomic, threading model, data transfer, and so on
- Develop a histogram in OpenCL
- Learn how to develop Sobel edge detection in OpenCL for image processing
- Develop the Matrix Multiplication and the Sparse Matrix Vector Multiplication in OpenCL
- Learn to develop Bitonic sort and Radix sort in OpenCL
- Develop n-body with OpenCL
商品描述(中文翻譯)
這本食譜書是學習 OpenCL 中平行程式設計的完美方式,因為它提供了啟發性的理論與實作食譜的結合。非常適合有經驗的開發者。
**概述**
- 了解 OpenCL 中的平行程式設計開發,以及撰寫高效能程式碼所涉及的各種技術
- 進一步了解資料平行或任務平行開發,以及兩者的結合
- 理解並利用底層硬體特性,如處理器暫存器和快取,這些特性可以在處理器上運行數以萬計的執行緒
**詳細內容**
OpenCL(開放計算語言)是第一個免版稅的標準,用於現代處理器的跨平台平行程式設計,這些處理器存在於個人電腦、伺服器、行動裝置和嵌入式設備中。OpenCL 大幅提升了各種應用程式在多個市場類別中的速度和反應能力,從遊戲和娛樂到科學和醫療軟體。OpenCL 已證明其多功能性,現在不僅可以在由 Intel 和 AMD 處理器驅動的 Windows 和 Linux 等作業系統上運行,還可以在像 ARM 這樣的低功耗晶片上運行,並且也被 ARM Corp、Vivante 和 Altera 等處理器製造商採用。
《OpenCL 平行程式設計開發食譜》旨在實用,以便在理論和應用之間取得良好的平衡。以平行方式編程相對容易,但有效利用所有可用資源則大相逕庭。你需要了解的不僅是應用,還有其背後的理論。
這本書大致分為兩部分,第一部分是 OpenCL 平行開發的基礎,第二部分是我們將與你探索的各種演算法。每一部分都包含許多程式碼範例和插圖,以展示各種概念。第一部分對於初學者來說至關重要,不僅要能夠進行平行編程,還要能夠以平行的方式思考,並具備應對平行程式設計的心智模型。第二部分包含作者所識別的七種不同演算法;你將學習過去 60 年專家所使用的各種平行程式設計技術,這些技術適用於 OpenCL。
這本書將通過說明和演示資料分區、執行緒粗化、暫存器平鋪、資料預取和演算法轉換等程式設計技術,來展示你如何以平行的方式思考。這些技術在你將看到的七種演算法中得以展示,從影像處理和解決稀疏線性系統到內存排序。
《OpenCL 平行程式設計開發食譜》結合了食譜、插圖、程式碼和解釋,讓你學習 OpenCL 中平行程式設計的基本要素,作者還加入了足夠的數學內容,以便讀者理解動機,並為他們開始自己的探索奠定基礎。
**你將從這本書中學到什麼**
- 如何使用 OpenCL
- 理解 OpenCL 中的資料分區和傳輸
- 理解 OpenCL 資料類型
- 了解 OpenCL 函數,包括數學、原子、執行緒模型、資料傳輸等
- 在 OpenCL 中開發直方圖
- 學習如何在 OpenCL 中開發 Sobel 邊緣檢測以進行影像處理
- 在 OpenCL 中開發矩陣乘法和稀疏矩陣向量乘法
- 學習在 OpenCL 中開發 Bitonic 排序和基數排序
- 使用 OpenCL 開發 n-body 模型