《cuda c编程权威指南》03 - cuda小功能汇总

1. 计时

1.1 linux

#include 

double cpuSecond() {
	struct timeval tp;
	gettimeofday(&tp, NULL);
	return ((double)tp.tv_sec + (double)tp.tv_usec*1e-6);
}

// 调用
double start = cpuSecond();
kernel_name << > > (argument list);
cudaDeviceSynchronize();  // 显示的使其同步。
double cost = cpuSecond() - start;

1.2 window下

#include 

// 调用
time_t begin, end;
time(&begin);
kernel_name << > > (argument list);
time(&end);
time_t elapsed = end - begin;
printf("Time measured: %ld seconds.\n", elapsed);

2. nvprof实用工具

nvprof是命令行分析工具,功能很多,可以帮助从应用程序的CPU和GPU活动情况中获取时间线信息,其包括内核执行、内存传输以及CUDA API的调用。具体可通过以下命令查看。

nvprof --help

 上面命令如果报错:由于找不到cupti64_2022.2.1.dll,无法继续执行代码。。。

《cuda c编程权威指南》03 - cuda小功能汇总_第1张图片

原因:nvprof工具属于插件,其dll在目录: 

C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.7\extras\CUPTI\lib64

 系统环境没有该目录,所以索引不到dll库。

解决办法:由于C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.7\bin在系统环境中,可以将cupti64_2022.2.1.dll拷贝到bin目录中.

nvprof ./sumArraysOnGpu-timer

《cuda c编程权威指南》03 - cuda小功能汇总_第2张图片

(1)可以看到cudaMemcpy hostToDevice被运行了3次,平均用时17ms;

(2)核函数sumArraysOnGpu运行用时2.9ms,运行了1次。

 

待续。。。

你可能感兴趣的:(cuda,c语言,linux,开发语言)