This is a set of examples showing how to write parallelized code using OpenCL. All examples are in C++ and use the official OpenCL C++ wrapper (cl.hpp), which makes the code more concise and readable. Examples use OpenCL 1.2 for better portability.
-
add_vectors - Starting point for learning OpenCL; just adding two vectors
-
list_platforms - List available OpenCL platforms and some information on OpenCL capabilities
-
gl_particles - A simple particle simulation and an example of interoperability between OpenCL and OpenGL
There is a good number of OpenCL tutorials and examples available on-line but most of them use a spartan C99 OpenCL API. OpenCL is much easier to learn and program using the official C++ wrapper. C++ wrapper makes the code much more concise and protects against making some common mistakes.
There are also very few examples showing how OpenGL can be integrated with OpenGL. "gl_particles" serves this purpose.
We tested the code to work on Ubuntu 18.04 and Windows 10.
Note: You cannot use OpenCL from a Virtual Machine (for example Ubuntu running on Windows VM) as a virtual machine usually does not offer access to the GPU.
You need to install OpenCL SDK for (any) platform. As long as you have graphics card drivers are installed, the generic ICD loader will find the relevant driver for your platform.
Note that you need to install the native drivers (from Nvidia or AMD) on Linux. See for example: https://linuxconfig.org/how-to-install-the-nvidia-drivers-on-ubuntu-18-10-cosmic-cuttlefish-linux
You can get OpenCL SDK from:
- For Nvidia, OpenCL SDK is confusingly bundled with CUDA Toolkit https://developer.nvidia.com/cuda-downloads
On Ubuntu (tested on 18.04/bionic) it is possible to install the required files from packages:
sudo add-apt-repository ppa:graphics-drivers/ppa sudo apt-get update sudo apt-get install nvidia-cuda-toolkit
-
AMD: Linux: OpenCL ICD is bundled with AMD drivers. Get your card's driver from here: https://www.amd.com/en/support . The required headers can be installed using your package manager: sudo apt-get install opencl-headers
Windows: AMD has dropped the support for APP SDK and such any related package might not available on developer.amd.com. You can instead use this light SDK package available here: https://github.com/GPUOpen-LibrariesAndSDKs/OCL-SDK/releases
Use CMake to generate build files for your platform (VS, gnu, xcode, etc.) https://cmake.org/
"gl_particles" example requires a few more dependencies. If these are not found, the OpenGL example will be skipped from build but the rest of the examples will compile. The required libraries are:
-
FreeGLUT: http://freeglut.sourceforge.net/
On Linux the libraries can be easily installed from packages. Remember to install the development version of the packages (freeglut3-dev, libglew-dev, libglm-dev).
On Windows the libraries needs to be manually installed and then the path specified for each library in CMake.
The OpenGL example currently does not work on OSX.
As installation is a bit harder on Windows, we prepared this step-by-step instruction:
-
Install Intel OpenCL SDK from https://software.intel.com/en-us/intel-opencl (other SDKs could also work)
-
Install Mingw from https://sourceforge.net/projects/mingw-w64/
-
mkdir build
-
cd build
-
cmake -G "MinGW Makefiles" ../ (You may need to run this command twice)
-
mingw32-make
-
cd ../list_platforms
-
..\build\list_platforms\ocl_list_platforms.exe
Note that all examples must be run from the corresponding source directory. This is because each example needs to load OpenCL kernels (and OpenGL shaders) from the text file, which can be found in the source directories.