CUDA编程系列--详解CUDA核函数及运行时参数
来源:互联网 发布:c linux ide工具 编辑:程序博客网 时间:2024/06/15 10:58
核函数是GPU每个thread上运行的程序。必须通过__gloabl__函数类型限定符定义。形式如下:
__global__ void kernel(param list){ }
核函数只能在主机端调用,调用时必须申明执行参数。调用形式如下:
Kernel<<<Dg,Db, Ns, S>>>(param list);
<<<>>>运算符内是核函数的执行参数,告诉编译器运行时如何启动核函数,用于说明内核函数中的线程数量,以及线程是如何组织的。
<<<>>>运算符对kernel函数完整的执行配置参数形式是<<<Dg, Db, Ns, S>>>
- 参数Dg用于定义整个grid的维度和尺寸,即一个grid有多少个block。为dim3类型。Dim3 Dg(Dg.x, Dg.y, 1)表示grid中每行有Dg.x个block,每列有Dg.y个block,第三维恒为1(目前一个核函数只有一个grid)。整个grid中共有Dg.x*Dg.y个block,其中Dg.x和Dg.y最大值为65535。
- 参数Db用于定义一个block的维度和尺寸,即一个block有多少个thread。为dim3类型。Dim3 Db(Db.x, Db.y, Db.z)表示整个block中每行有Db.x个thread,每列有Db.y个thread,高度为Db.z。Db.x和Db.y最大值为512,Db.z最大值为62。 一个block中共有Db.x*Db.y*Db.z个thread。计算能力为1.0,1.1的硬件该乘积的最大值为768,计算能力为1.2,1.3的硬件支持的最大值为1024。
- 参数Ns是一个可选参数,用于设置每个block除了静态分配的shared Memory以外,最多能动态分配的shared memory大小,单位为byte。不需要动态分配时该值为0或省略不写。
- 参数S是一个cudaStream_t类型的可选参数,初始值为零,表示该核函数处在哪个流之中。
0 0
- CUDA编程系列--详解CUDA核函数及运行时参数
- 【走进CUDA】~详解CUDA核函数及运行时参数
- 详解CUDA核函数及运行时参数<<<>>>
- 详解CUDA核函数及运行时参数<<<>>>
- 详解CUDA核函数及运行时参数
- 详解CUDA核函数及运行时参数
- CUDA核函数及运行时参数
- CUDA/ GPU: CUDA核函数的运行参数
- GPU编程自学4 —— CUDA核函数运行参数
- 【CUDA并行程序设计系列(2)】CUDA简介及CUDA初步编程
- CUDA deviceQuery参数详解
- CUDA编程主函数模板及实例
- CUDA编程(二) CUDA初始化与核函数
- CUDA编程(二) CUDA初始化与核函数
- CUDA编程基础系列1
- cuda内核(kernel)参数详解
- cuda内核(kernel)参数详解
- CUDA编程经验技术总结 系列之《核函数之线程技术》
- mysql ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing t
- 快捷键--快速操作Linux终端命令行
- 二、tomcat启动startup.bat一闪而过
- Hadoop环境搭建
- C:forEach的使用:仪表所附件显示异常修复
- CUDA编程系列--详解CUDA核函数及运行时参数
- java多线程并发(二)——线程池Executors
- 三、运行Tomcat9.0,jdk1.7出现tomcat unsupported major.minor version 52.0
- 动态规划 10题
- 0419学习总结(数组,函数,预处理)
- 排序模板链表的插入存储和二分查找
- String(byte bytes[], String charsetName)
- vue-router,利用router.beforeEach未登录跳转到登录页
- (c语言)选择排序与冒泡排序