1<html> 2<head> 3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 4<title>Design</title> 5<link rel="stylesheet" href="../../../../../doc/src/boostbook.css" type="text/css"> 6<meta name="generator" content="DocBook XSL Stylesheets V1.79.1"> 7<link rel="home" href="../index.html" title="Chapter 1. Boost.Compute"> 8<link rel="up" href="../index.html" title="Chapter 1. Boost.Compute"> 9<link rel="prev" href="getting_started.html" title="Getting Started"> 10<link rel="next" href="tutorial.html" title="Tutorial"> 11</head> 12<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"> 13<table cellpadding="2" width="100%"><tr> 14<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../boost.png"></td> 15<td align="center"><a href="../../../../../index.html">Home</a></td> 16<td align="center"><a href="../../../../../libs/libraries.htm">Libraries</a></td> 17<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td> 18<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td> 19<td align="center"><a href="../../../../../more/index.htm">More</a></td> 20</tr></table> 21<hr> 22<div class="spirit-nav"> 23<a accesskey="p" href="getting_started.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../index.html"><img src="../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="tutorial.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a> 24</div> 25<div class="section"> 26<div class="titlepage"><div><div><h2 class="title" style="clear: both"> 27<a name="boost_compute.design"></a><a class="link" href="design.html" title="Design">Design</a> 28</h2></div></div></div> 29<div class="toc"><dl class="toc"> 30<dt><span class="section"><a href="design.html#boost_compute.design.library_architecture">Library Architecture</a></span></dt> 31<dt><span class="section"><a href="design.html#boost_compute.design.why_opencl">Why OpenCL</a></span></dt> 32</dl></div> 33<div class="section"> 34<div class="titlepage"><div><div><h3 class="title"> 35<a name="boost_compute.design.library_architecture"></a><a class="link" href="design.html#boost_compute.design.library_architecture" title="Library Architecture">Library Architecture</a> 36</h3></div></div></div> 37<p> 38 The Boost Compute library consists of several different components. The core 39 layer provides a "thin" C++ wrapper over the OpenCL API. This includes 40 classes to manage OpenCL objects such as <code class="computeroutput">device</code>'s, 41 <code class="computeroutput">kernel</code>'s and <code class="computeroutput">command_queue</code>'s. 42 </p> 43<p> 44 On top of the core layer is a partial implementation of the C++ standard 45 library providing common containers (e.g. <code class="computeroutput"><a class="link" href="../boost/compute/vector.html" title="Class template vector">vector<T></a></code>, 46 <code class="computeroutput"><a class="link" href="../boost/compute/array.html" title="Class template array">array<T, N></a></code>) along 47 with common algorithms (e.g. <code class="computeroutput"><a class="link" href="../boost/compute/transform.html" title="Function transform">transform()</a></code> 48 and <code class="computeroutput"><a class="link" href="../boost/compute/sort.html" title="Function sort">sort()</a></code>). 49 </p> 50<p> 51 The library also provides a number of "fancy" iterators (e.g. 52 <code class="computeroutput"><a class="link" href="../boost/compute/transform_iterator.html" title="Class template transform_iterator">transform_iterator</a></code> 53 and <code class="computeroutput"><a class="link" href="../boost/compute/permutation_iterator.html" title="Class template permutation_iterator">permutation_iterator</a></code>) 54 which enhance the functionality of the standard algorithms. 55 </p> 56<p> 57 Boost.Compute also supplies a number of facilities for interoperation with 58 other C and C++ libraries. See the section on <a class="link" href="interop.html" title="Interoperability">interoperability</a> 59 for more information. 60 </p> 61<p> 62 See the <a class="link" href="reference.html#boost_compute.reference.api_overview" title="API Overview">API Overview</a> 63 section for a full list of functions, classes, and macros provided by Boost.Compute. 64 </p> 65</div> 66<div class="section"> 67<div class="titlepage"><div><div><h3 class="title"> 68<a name="boost_compute.design.why_opencl"></a><a class="link" href="design.html#boost_compute.design.why_opencl" title="Why OpenCL">Why OpenCL</a> 69</h3></div></div></div> 70<p> 71 Boost.Compute uses <a href="http://en.wikipedia.org/wiki/OpenCL" target="_top">OpenCL</a> 72 as its interface for executing code on parallel devices such as GPUs and 73 multi-core CPUs. 74 </p> 75<p> 76 OpenCL was chosen for a number of reasons: 77 </p> 78<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "> 79<li class="listitem"> 80 Vendor-neutral, standard C/C++, and doesn't require a special compiler, 81 non-standard pragmas, or compiler extensions. 82 </li> 83<li class="listitem"> 84 It is not just another parallel-library abstraction layer, it provides 85 direct access to the underlying hardware. 86 </li> 87<li class="listitem"> 88 Its runtime compilation model allows for kernels to be optimized and 89 tuned dynamically for the device present when the application is run 90 rather that the device that was present when the code was compiled (which 91 is often a separate machine). 92 </li> 93<li class="listitem"> 94 Using OpenCL allows Boost.Compute to directly interoperate with other 95 OpenCL libraries (such as VexCL and OpenCV), as well as existing code 96 written with OpenCL. 97 </li> 98<li class="listitem"> 99 The "thin" C++ wrapper provided by Boost.Compute allows the 100 user to break-out and write their own custom kernels when the provided 101 APIs are not suitable. 102 </li> 103</ul></div> 104</div> 105</div> 106<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr> 107<td align="left"></td> 108<td align="right"><div class="copyright-footer">Copyright © 2013, 2014 Kyle Lutz<p> 109 Distributed under the Boost Software License, Version 1.0. (See accompanying 110 file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>) 111 </p> 112</div></td> 113</tr></table> 114<hr> 115<div class="spirit-nav"> 116<a accesskey="p" href="getting_started.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../index.html"><img src="../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="tutorial.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a> 117</div> 118</body> 119</html> 120