Boost C++ Libraries of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards


Getting Started

Compilation and Usage
Configuration Macros

Boost.Compute is available in Boost starting with version 1.61. Visit for download instructions.

Boost.Compute is a header-only library, so no linking is required. To use the library just add the include directory to the compilation flags and link with the system's OpenCL library. For example, with GCC:

g++ -I/path/to/compute/include main.cpp -lOpenCL

All of the Boost.Compute headers can be included with the following directive:

#include <boost/compute.hpp>

If you only want to include the core OpenCL wrapper headers (which have minimal dependencies on the rest of Boost), use the following directive:

#include <boost/compute/core.hpp>

All of the classes and functions in Boost.Compute live in the boost::compute namespace and can be brought into global scope with:

using namespace boost::compute;

Boost.Compute provides a number of optional features which can be configured with the following macros.




When defined, if program::build() fails, the program source and build log will be written to stdout.


Enables the use of C++11 thread_local storage specifier.


Builds Boost.Compute in a thread-safe mode. This requires either support for C++11 thread-local storage (via defining the BOOST_COMPUTE_HAVE_THREAD_LOCAL macro) or linking with Boost.Thread.


Enables the offline-cache which stores compiled binaries on disk. This option requires linking with Boost.Filesystem and Boost.System.

Bugs and issues can be reported to the issue tracker.

There is also a mailing list for users and developers at!forum/boost-compute.

Look through the FAQ to see if you're encountering a known or common issue.