- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 OpenCL 生态系统以及 Vulkan 如何发挥作用。
鉴于此,
OpenCL 与 Vulkan 有何关系?我知道 OpenCL 更高级别并抽象了设备,但它是否(或可以)在内部使用 Vulkan? (而不是依赖供应商特定的驱动程序)
Vulkan 被宣传为计算和图形 API,但我发现计算部分的资源很少。这是为什么?
Vulkan 比 OpenGL 具有性能优势。 Vulkan 与 OpenCl 的情况相同吗? (遗憾的是,OpenCL 因比 CUDA 慢而臭名昭著。)
SYCL 在内部使用 OpenCL 还是可以使用 Vulkan?或者它两者都不使用,而是依赖于低级别、供应商特定的 API 来实现?
最佳答案
How does OpenCL relates to vulkan ? I understand that OpenCL is higher level and abstracts the devices, but does ( or could ) it uses Vulkan internally ?
他们之间根本没有关系。
嗯,从技术上来说,它们确实使用相同的中间着色器语言,但是 Vulkan 禁止 Kernel 执行模型,而 OpenCL 禁止 Shader 执行模型。因此,您不能只采用适用于 OpenCL 的着色器并将其粘贴到 Vulkan 中,反之亦然。
Vulkan is advertised as both a compute and graphics api, however I found very little resources for the compute part - why is that ?
因为 Khronos Group 喜欢误导性的营销宣传。
Vulkan 与 OpenGL 一样,只是一个计算 API。它可能有计算着色器,但它们的功能有限。您可以在 OpenCL 计算操作中执行的操作无法通过 OpenGL/Vulkan CS 执行。
Vulkan CS 与 OpenGL 的 CS 一样,旨在用于一件事:支持图形操作。要进行视锥体剔除、构建间接图形命令、操纵粒子系统等。 CS 的运行数值精度与图形着色器相同。
Vulkan has a performance advantages over OpenGL. Is the same true for Vulkan vs OpenCl?
计算系统的性能主要取决于其实现的质量。并不是 OpenCL 慢,而是 OpenCL 慢。这是您的 OpenCL 实现比可能的速度要慢。
Vulkan CS 在这方面没有什么不同。性能将取决于驱动程序的成熟度。
此外,事实上,您可以在 OpenCL 计算操作中执行许多在 Vulkan CS 中无法执行的操作。
Does SYCL uses OpenCL internally or could it use vulkan ?
来自 Khronos 集团:
SYCL (pronounced ‘sickle’) is a royalty-free, cross-platform abstraction layer that builds on the underlying concepts, portability and efficiency of OpenCL...
所以是的,它构建在 OpenCL 之上。
关于OpenCL、Vulkan、Sycl,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40703655/
Intel、AMD 和 Khronos OpenCL 之间有什么区别。我对 OpenCL 完全陌生,想从它开始。我不知道在我的操作系统上安装哪个更好。 最佳答案 OpenCL 是 C 和 C++ 语言
我在这里的一篇文章中看到,我们可以从 OpenCL 内核调用函数。但是在我的情况下,我还需要并行化该复杂函数(由所有可用线程运行),所以我是否必须将该函数也设为内核并像从主内核中调用函数一样直接调
最近我看到一些开发板支持 OpenCL EP,例如 odroid XU。我知道的一件事是 OpenCL EP 适用于 ARM 处理器,但它与基于主要桌面的 OpenCL 在哪些特性上有所不同。 最佳答
我想知道在 OpenCL 中设置为内核函数的参数数量是否有任何限制。设置参数时出现 INVALID_ARG_INDEX 错误。我在内核函数中设置了 9 个参数。请在这方面帮助我。 最佳答案 您可以尝试
我对零拷贝的工作原理有点困惑。 1-要确认以下内容对应于opencl中的零拷贝。 ....................... . . . .
我是 OpenCL 的初学者,我很难理解某些东西。 我想改进主机和设备之间的图像传输。 我制定了一个计划以更好地了解我。 顶部:我现在拥有的 |底部:我想要的 HtD(主机到设备)和 DtH(设备到主
今天我又加了四个 __local变量到我的内核以转储中间结果。但是只需将另外四个变量添加到内核的签名并添加相应的内核参数就会将内核的所有输出呈现为“0”。没有一个 cl 函数返回错误代码。 我进一步尝
我知道工作项被分组到工作组中,并且您不能在工作组之外进行同步。 这是否意味着工作项是并行执行的? 如果是这样,使用 128 个工作项创建 1 个工作组是否可能/有效? 最佳答案 组内的工作项将一起安排
我相当确定经纱仅在 CUDA 中定义。但也许我错了。就 OpenCL 而言,什么是扭曲? 它与工作组不一样,是吗? 任何相关的反馈都受到高度赞赏。谢谢! 最佳答案 它没有在 OpenCL 标准中定义。
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
在OpenCL中,我的理解是可以使用barrier()函数来同步工作组中的线程。我(通常)确实了解它们的用途以及何时使用它们。我还知道工作组中的所有线程都必须遇到障碍,否则会出现问题。然而,到目前为止
我的主板上有 Nvidia 显卡 (GeForce GT 640)。我已经在我的盒子上安装了 OpenCL。当我使用“clGetPlatformInfo(参数)”查询平台时,我看到以下输出:-#可用平
我目前正在构建一个 ray marcher 来查看像 mandelbox 等东西。它工作得很好。但是,在我当前的程序中,它使用每个 worker 作为从眼睛转换的光线。这意味着每个 worker 有大
我编写了两个不同的 openCl 内核,使用 nvidia profiler 获取了有关它们的一些信息,发现两者每个工作项都使用 63 个寄存器。 我尝试了一切我能想到的方法来降低这个数字(用 ush
我的主板上有 Nvidia 显卡 (GeForce GT 640)。我已经在我的盒子上安装了 OpenCL。当我使用“clGetPlatformInfo(参数)”查询平台时,我看到以下输出:-#可用平
我目前正在构建一个 ray marcher 来查看像 mandelbox 等东西。它工作得很好。但是,在我当前的程序中,它使用每个 worker 作为从眼睛转换的光线。这意味着每个 worker 有大
我正在尝试使用 OpenCL 加速一些计算,算法的一部分包括矩阵求逆。是否有任何开源库或免费可用的代码来计算用 OpenCL 或 CUDA 编写的矩阵的 lu 分解(lapack dgetrf 和 d
我正在尝试在 OpenCL 内核中使用递归。编译成功,但运行时出现编译错误,所以我想知道,由于 CUDA 现在支持动态并行,OpenCL 是否支持动态并行? 最佳答案 OpenCL 不支持递归。请参阅
考虑以下代码,它从大小为 size 的 double 组创建缓冲区内存对象: coef_mem = clCreateBuffer(context, CL_MEM_READ_WRITE | CL_MEM
OpenCL 中目标平台的示例是什么?例如,它是 Windows、Android、Mac 等操作系统,还是设备中的实际芯片? 最佳答案 OpenCL 平台本质上是一个 OpenCL 实现。它与操作系统
我是一名优秀的程序员,十分优秀!