opencl-clhpp/README.en.md

54 lines
1.9 KiB
Markdown
Raw Permalink Normal View History

2021-11-12 10:23:47 +08:00
# OpenCL<sup>TM</sup> API C++ bindings
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
Doxgen documentation for the cl2.hpp header is available here:
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
http://khronosgroup.github.io/OpenCL-CLHPP/
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
Components:
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
* `include/CL/cl2.hpp`:
The latest, maintained, version of the C++ bindings. It should work with all
versions of OpenCL (including 1.x). This is what most users will want.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
* `docs`:
Doxygen file used to generate HTML documentation for `cl2.hpp`.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
* `examples`:
A simple example application using the very basic features of the bindings.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
* `tests`:
A (very small, incomplete) set of regression tests. Building the tests
requires Python, Ruby, Unity and CMock. For the last two we use
[Unity 2.1.0](https://github.com/ThrowTheSwitch/Unity/releases/tag/v2.1.0)
and [CMock top-of-tree from Github](https://github.com/ThrowTheSwitch/CMock)
(the version 2.0.204 on Sourceforge does not work).
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
* `CMakeLists.txt`:
Build system for the examples and tests and logic for the bindings
installation.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
To get external dependencies needed for testing, use `--recursive` when cloning
the repository, or run `git submodule update --init`.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
You may need to tell CMake where to find the OpenCL headers and libraries,
using the variables `OPENCL_INCLUDE_DIR` and `OPENCL_LIB_DIR`.
2021-11-11 01:57:54 +00:00
2021-11-12 10:23:47 +08:00
These can be set either as environment variables, or on the cmake command line
using the syntax `-D<VAR>=<VALUE>`.
The following is an example set of commands to checkout and build the C++
bindings (adapt paths as required):
```
git clone --recursive https://github.com/KhronosGroup/OpenCL-CLHPP
cd OpenCL-CLHPP
mkdir build
cd build
cmake .. -DOPENCL_INCLUDE_DIR=/path/to/OpenCL/headers -DOPENCL_LIB_DIR=/path/to/OpenCL/library
make
make test
```
After building, the headers appear in `build/include/CL/`.
If Doxygen is available, you can generate HTML documentation by typing `make docs`.