▶ 本章介绍了原子操作,给出了基于原子操作的直方图计算的例子. ● 章节代码 #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include "D:\Code\CUDA\book\common\book.h" #define SIZE (100*1024*1024) #define USE_SHARE_MEMORY…
以下问题的出现及解决都基于"WIN7+CUDA7.5". 问题描述:当我编译运行<GPU高性能编程CUDA实战>中第4章所给Julia实例代码时,出现了显示器闪动的现象,现象很快消失,并在窗口右下角弹出"显示器驱动已停止响应,并且已恢复"的提示,而最终并未得到Julia应有的计算结果,在命令行窗口中显示了相应错误信息. 问题解决:开始 > NVIDIA Corporation > Nsight Visual Studio Edition 4.…
▶ 本章介绍了常量内存的使用,并给光线追踪的一个例子.介绍了结构cudaEvent_t及其在计时方面的使用. ● 章节代码,大意是有SPHERES个球分布在原点附近,其球心坐标在每个坐标轴方向上分量绝对值不大于500,其半径介于20到120:观察者(画面平面)位于z正半轴充分远处(z>500),现将所有的球体平行投影到画面平面上,考虑遮挡关系,并考虑球面与画面平面的夹角给球体绘制阴影. #include <stdio.h> #include "cuda_runtime.h&qu…
▶ 本章介绍了多设备胸膛下的 CUDA 编程,以及一些特殊存储类型对计算速度的影响 ● 显存和零拷贝内存的拷贝与计算对比 #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include "D:\Code\CUDA\book\common\book.h" #define imin(a,b) (a<b?a:b) #…
▶ 本章介绍了线程并行,并给出四个例子.长向量加法.波纹效果.点积和显示位图. ● 长向量加法(线程块并行 + 线程并行) #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include "D:\Code\CUDA\book\common\book.h" #define N (33 * 1024) __global_…
▶ 本章介绍了线程块并行,并给出两个例子:长向量加法和绘制julia集. ● 长向量加法,中规中矩的GPU加法,包含申请内存和显存,赋值,显存传入,计算,显存传出,处理结果,清理内存和显存.用到了 tid += gridDim.x; 使得线程块可以读取多个下标,计算长于线程块数量的向量(例子中向量长度为32768,线程块数量为1024) #include <stdio.h> #include "cuda_runtime.h" #include "device_la…
▶ 本章介绍了纹理内存的使用,并给出了热传导的两个个例子.分别使用了一维和二维纹理单元. ● 热传导(使用一维纹理) #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include "D:\Code\CUDA\book\common\book.h" #include "D:\Code\CUDA\book\c…
▶ 这章介绍了与CUDA设备相关的参数,并给出了了若干用于查询参数的函数. ● 代码(已合并) #include <stdio.h> #include "cuda_runtime.h" #include "device_launch_parameters.h" #include "D:\Code\CUDA\book\common\book.h" int main(void) { cudaDeviceProp prop; //放置设备属…
在整个过程中出现了各种问题,我先将我调试好的真个项目打包,提供下载. /* * Copyright 1993-2010 NVIDIA Corporation. All rights reserved. * * NVIDIA Corporation and its licensors retain all intellectual property and * proprietary rights in and to this software and related documentation.…
▶ 使用CPU和GPU分别实现散列表 ● CPU方法 #include <stdio.h> #include <time.h> #include "cuda_runtime.h" #include "D:\Code\CUDA\book\common\book.h" #define SIZE (100*1024*1024) #define ELEMENTS (SIZE / sizeof(unsigned int)) #define HASH_E…