首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在CUDA中,通过clock()和clock64()测量的时钟是什么?

在CUDA中,通过clock()和clock64()测量的时钟是什么?
EN

Stack Overflow用户
提问于 2014-11-22 00:21:59
回答 1查看 6.8K关注 0票数 4

在CUDA中,clock()clock64()测量的时钟是多少?

根据CUDA documentation的说法,时钟是“每个多处理器的计数器”。根据我的理解,这指的是主GPU时钟(不是着色器时钟)。

但是,当我使用主GPU时钟频率测量时钟计数并将其转换为时间值时,我得到的结果是实际值的两倍(我使用cuda事件使用主机代码的内核执行时间来测量实际值)。这表明clock()返回着色器时钟频率,而不是主GPU时钟。

我怎样才能解决这个困惑呢?

编辑:我通过将从cudaGetDeviceProperties获得的时钟频率除以2来计算主图形处理器时钟频率。据我所知,cudaGetDeviceProperties给出的值是着色器时钟频率。

EN

回答 1

Stack Overflow用户

发布于 2014-11-22 01:37:41

确实,CUDA documentationclock()clock64()返回“每个多处理器的计数器”。但在费米架构中,clock()clock64()实际上返回的是着色器时钟计数器。

cudaGetDeviceProperties返回的clockRate是着色器时钟频率。

因此,为了计算时间,我们必须将来自clock()clock64()的时钟计数除以从cudaGetDeviceProperties获得的着色器时钟频率。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27065862

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档