-
Notifications
You must be signed in to change notification settings - Fork 24
GPU
Most GPU computation uses NVIDIA's CUDA framework. However, this is not ideal for a number of reasons:
- Only runs on NVIDIA hardware -- Mac laptops for example do not use NVIDIA anymore, and for local development and testing, it is ideal to be able to run on the laptop. Or even the phone in the future.
- Closed source.
- C-based -- integration with Go is not ideal.
Probably the best way forward is to use Vulkan, which is open source, universally-supported, and has (low level) compute capabilities built in. There are some recent reports that it is becoming competitive performance-wise with CUDA. There was also OpenCL, but Apple has abandoned it, and it is widely regarded as dying.
The problem with Vulkan is that it is very low-level, "close to the metal", so it can be highly verbose to just get anything at all working. Thus, various forms of infrastructure are emerging that provide a more high-level interface on top of Vulkan. Of course, most of these are in C, but they provide a good place to start for a Go version.
- Kompute: https://towardsdatascience.com/machine-learning-and-data-processing-in-the-gpu-with-vulkan-kompute-c9350e5e5d3a
- VUDA: https://github.com/jgbit/vuda
- Blog about Vulkan compute: https://raphlinus.github.io/gpu/2020/04/30/prefix-sum.html
- and his resources: https://raphlinus.github.io/gpu/2020/02/12/gpu-resources.html
test