A collection of samples and graphical demos written using SYCL.
This demo simulates Conway's Game of Life with a dynamically resizable grid. To draw new cells, hold the mouse button and drag the mouse slowly over the grid. Press SPACE to pause/resume the simulation. To resize the grid, use the mouse wheel. Doing this or resizing the window will reset the simulation.
This demo dynamically renders and displays a visualization of the Mandelbrot set on the complex plane. Use the mouse wheel to zoom in or out and drag the mouse while holding the mouse button to move around the plane.
This demo demonstrates the use of numerical integration methods to simulate systems of interacting bodies, where every body exerts a force on every other body. A graphical interface is provided to set the force type, the integration method, and the initial distribution of bodies. The simulation can be initialized from there. The simulation can be viewed from different positions by dragging the mouse and using the mouse wheel to control the camera.
This demo visualizes fluid behaviour in a closed container. Each cell in the cellular automata represents a fluid particle existing in a velocity field. Drag mouse around the screen to create fluid particles with velocities in direction of mouse travel. Fluid fades slowly over time so as not to fill the container.
The graphical demos use
Magnum
(and its dependency
Corrade)
for the graphics and UI abstraction with the
SDL2 implementation. Magnum and
Corrade are built as part of this project through git submodules. Make sure to
include them in the checkout via
git clone --recurse-submodules <this repo's URL>
. SDL2 needs to be supplied by
the user and can be installed with common package managers on most systems, or
built from source. If you install SDL2 from source in a non-default location,
pass it into the CMake configuration with -DSDL2_ROOT=<path>
.
Although the code should compile with any SYCL implementation, the CMake configuration assumes the DPC++ compiler driver CLI for compilation flags setup. Both the Intel DPC++ release and the open source version are compatible.
The project uses a standard CMake build system. To check out the repository and build the examples, use simply:
git clone --recurse-submodules <this repo's URL>
cd SYCL-samples
mkdir build && cd build
cmake ..
cmake --build .
Make sure the SYCL compiler is used by the configuration either by setting the
environment variable CXX=<compiler>
or passing the configuration flag
-DCMAKE_CXX_COMPILER=<compiler>
where <compiler>
is your SYCL compiler's
executable (for example icpx
or clang++
).
The CMake configuration automatically detects the available SYCL backends and
enables the SPIR/CUDA/HIP targets for the device code, including the
corresponding architecture flags. If desired, these auto-configured options may
be overridden with -D<OPTION>=<VALUE>
with the following options:
<OPTION> |
<VALUE> |
---|---|
ENABLE_SPIR |
ON or OFF |
ENABLE_CUDA |
ON or OFF |
ENABLE_HIP |
ON or OFF |
CUDA_COMPUTE_CAPABILITY |
Integer, e.g. 70 meaning capability 7.0 (arch sm_70 ) |
HIP_GFX_ARCH |
String, e.g. gfx1030 |